Contract Overview
Balance: 0 Ether
Transactions: 27 txns
 Latest 25 transactions from a total of 27 transactions

TxHash Age From To Value [TxFee]
0xe441e26b389d25625aab1034f17f296e6013c2ae99d317361fa31c5c533ae54025 days 9 hrs ago0x17729f113b598f9fd8d8c119ec557e1cabf0d1e5  IN   0xa7a8b1c9b519deccee933102e29bb8c8b269da4c1 Ether0.009800968
0x76a4facb45b3d91f6e5a657d0747fe8ddbb7486797875f53590d69a7fa96b7c725 days 9 hrs ago0x17729f113b598f9fd8d8c119ec557e1cabf0d1e5  IN   0xa7a8b1c9b519deccee933102e29bb8c8b269da4c1 Ether0.008314349
0x5ea5f196b13dfca3c84223b667f15970b7431286cf1843df64a572df5f83ec7f25 days 15 hrs ago0x0efa8015fcec7039feb656a4830aa6518bf46010  IN   0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0.172 Ether0.005757548
0x488f51cc9aaf05dc8da6e6dd930300cc50c4d28fd0d0179cd4e44ab3d709298325 days 15 hrs ago0x0efa8015fcec7039feb656a4830aa6518bf46010  IN   0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0.172 Ether0.005757548
0x53c34df1d816b6afa77f2cdf5462baa725e9252bff7f58cfc16b0abf26eeb8ba25 days 15 hrs ago0x0efa8015fcec7039feb656a4830aa6518bf46010  IN   0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0.172 Ether0.009056408
0x5f6f0966ddf3b89055bffcff75bffd3db993fa7d287a8d3b5b48bd5ab3abaad925 days 17 hrs ago0x1b40e67dfba209baf00d16734deb9bf16471ea54  IN   0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0.88 Ether0.005822574
0x4addb73cf4c0f0713c2ed530a7aeccdd0a0d8f2e57c0b959e138bc1f090c8ec625 days 17 hrs ago0x57eb89f0e5f659bab8eeac9b357b0cabd57ab2e7  IN   0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0.88 Ether0.005822574
0xf92f75cba6f0da0bd455c04975707ea127e4bdc88bcd2cab92a4e32e07ef6e8325 days 17 hrs ago0x1b40e67dfba209baf00d16734deb9bf16471ea54  IN   0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0.172 Ether0.00569039
0xa0c2c53095d358df4009255ab1fe096e7ea46751abbee8cb37f83a5a9dfc4ca725 days 17 hrs ago0x2f135c2fe00c475a5dab57f7af02d47270893e91  IN   0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0.172 Ether0.005757548
0xe5d4e393b7a0b31756e3415453afd55af6cc7b205c1005db83686d580f8840aa25 days 17 hrs ago0x2f135c2fe00c475a5dab57f7af02d47270893e91  IN   0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0.172 Ether0.005754924
0x614fad92ea78665905a9e24c428bc230b9be90b9d0bca9874a0a64e3ed35b19825 days 18 hrs ago0x46fa069a6ca1d00112d388f04a9af5ede380339b  IN   0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0.9 Ether0.005822574
0x7544622ccfdcd0cea3ca8ca9f8c3d2388be211e324931af5c4c05d5adc2c771f25 days 18 hrs ago0x2f135c2fe00c475a5dab57f7af02d47270893e91  IN   0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0.172 Ether0.009668784
0x1726ac46b25f8672ea29ae393fd193a71b4a2c17d5a513863af4283c237ae38a25 days 18 hrs ago0x1b40e67dfba209baf00d16734deb9bf16471ea54  IN   0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0.172 Ether0.00569039
0x307992ea0802156b5b941502bda39d6ad48b0fc5246ad5d5cdd3a746fc3bdb2b25 days 18 hrs ago0x1b40e67dfba209baf00d16734deb9bf16471ea54  IN   0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0.172 Ether0.008182165
0x08e8b441a10cf57a66431348dd82554d5975539b8d0ca875f0e4f743a25f2db125 days 18 hrs ago0x57eb89f0e5f659bab8eeac9b357b0cabd57ab2e7  IN   0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0.175 Ether0.008182165
0x4757667294c764d5ed2eca167aa0c03e81793a64279ec880ae5ada97a2cf5e0525 days 18 hrs ago0x0efa8015fcec7039feb656a4830aa6518bf46010  IN   0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0.173 Ether0.008182165
0xe4b741cfb97296a00dd526cfb842db6ff3b239a183e4d1d95dfd12643fc9739425 days 19 hrs ago0x0efa8015fcec7039feb656a4830aa6518bf46010  IN   0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0.173 Ether0.00012258
0xdc5f006d46a9e91440f53d9223c3c07b209eea3dc7a721e179801cdcadac286925 days 19 hrs ago0x0efa8015fcec7039feb656a4830aa6518bf46010  IN   0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0.173 Ether0.000122196
0x827440ddaaf02f5aed3ce1aea5cc41357d31c5e5507e78ead4765b2cd59d449e26 days 4 hrs ago0xfa6f715a9e13041a3a6ade51db6802138e577fbb  IN   0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0.2 Ether0.005757548
0x121c7cae5a7b8fcc32fc15ff1e3d2b97ebc3ed12fb5b5c8c0c888f7992e4022926 days 4 hrs ago0xfa6f715a9e13041a3a6ade51db6802138e577fbb  IN   0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0.2 Ether0.010283784
0xa2bd62004d11804936e3a18052bfe921b13dd4e36e7b1e89a56a39cde33c95e226 days 4 hrs ago0xfa6f715a9e13041a3a6ade51db6802138e577fbb  IN   0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0.2 Ether0.000209101
0xa2f2e57dd2ada7e257b7d957468df512c589837be075105c3eeafd76ae09f3c526 days 4 hrs ago0xfa6f715a9e13041a3a6ade51db6802138e577fbb  IN   0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0.2 Ether0.000209102
0x74bf647af09c8059f45b7bf3b43d913c2a309de77233f0c685cc640bdf359f2d26 days 4 hrs ago0xfa6f715a9e13041a3a6ade51db6802138e577fbb  IN   0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0.2 Ether0.000627306
0x87294a0b8e3c37e5923d1d0f1e9159ec0e0c3087dd2a1251264216ef396406c526 days 13 hrs ago0x0b30df42e49d3906f0c50916d6e99727b58a8650  IN   0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0.162100826714216 Ether0.000168296
0xf53328b331b466bfbe88ea908077a068816c47f7e9b73a90be1730fb676cdb3426 days 13 hrs ago0x0b30df42e49d3906f0c50916d6e99727b58a8650  IN   0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0.00810504133571 Ether0.000035417
[ Download CSV Export  ] 
 Internal Transactions as a result of Contract Execution
 Latest 25 Internal Txns, Click here To View More View All
ParentTxHash Block Age From To Value
0xe441e26b389d25625aab1034f17f296e6013c2ae99d317361fa31c5c533ae540486842225 days 9 hrs ago0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0x0b30df42e49d3906f0c50916d6e99727b58a86501 Ether
0xe441e26b389d25625aab1034f17f296e6013c2ae99d317361fa31c5c533ae540486842225 days 9 hrs ago0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0x5ef633ff6f33a161dff9963f17b0b0eab6e6451c0 Ether
0xe441e26b389d25625aab1034f17f296e6013c2ae99d317361fa31c5c533ae540486842225 days 9 hrs ago0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0x2ad2387607ae62884c99beb473f34dcdfacc5a3c0 Ether
0xe441e26b389d25625aab1034f17f296e6013c2ae99d317361fa31c5c533ae540486842225 days 9 hrs ago0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0x9edeeb91266f1f2453fbdd67cd00f3dff1575ced0 Ether
0xe441e26b389d25625aab1034f17f296e6013c2ae99d317361fa31c5c533ae540486842225 days 9 hrs ago0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0x9edeeb91266f1f2453fbdd67cd00f3dff1575ced0 Ether
0xe441e26b389d25625aab1034f17f296e6013c2ae99d317361fa31c5c533ae540486842225 days 9 hrs ago0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0x2ad2387607ae62884c99beb473f34dcdfacc5a3c0 Ether
0xe441e26b389d25625aab1034f17f296e6013c2ae99d317361fa31c5c533ae540486842225 days 9 hrs ago0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0x9edeeb91266f1f2453fbdd67cd00f3dff1575ced0 Ether
0xe441e26b389d25625aab1034f17f296e6013c2ae99d317361fa31c5c533ae540486842225 days 9 hrs ago0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0x9edeeb91266f1f2453fbdd67cd00f3dff1575ced0 Ether
0x76a4facb45b3d91f6e5a657d0747fe8ddbb7486797875f53590d69a7fa96b7c7486837125 days 9 hrs ago0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0x0b30df42e49d3906f0c50916d6e99727b58a86501 Ether
0x76a4facb45b3d91f6e5a657d0747fe8ddbb7486797875f53590d69a7fa96b7c7486837125 days 9 hrs ago0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0x5ef633ff6f33a161dff9963f17b0b0eab6e6451c0 Ether
0x76a4facb45b3d91f6e5a657d0747fe8ddbb7486797875f53590d69a7fa96b7c7486837125 days 9 hrs ago0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0x2ad2387607ae62884c99beb473f34dcdfacc5a3c0 Ether
0x76a4facb45b3d91f6e5a657d0747fe8ddbb7486797875f53590d69a7fa96b7c7486837125 days 9 hrs ago0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0x9edeeb91266f1f2453fbdd67cd00f3dff1575ced0 Ether
0x76a4facb45b3d91f6e5a657d0747fe8ddbb7486797875f53590d69a7fa96b7c7486837125 days 9 hrs ago0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0x9edeeb91266f1f2453fbdd67cd00f3dff1575ced0 Ether
0x76a4facb45b3d91f6e5a657d0747fe8ddbb7486797875f53590d69a7fa96b7c7486837125 days 9 hrs ago0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0x2ad2387607ae62884c99beb473f34dcdfacc5a3c0 Ether
0x76a4facb45b3d91f6e5a657d0747fe8ddbb7486797875f53590d69a7fa96b7c7486837125 days 9 hrs ago0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0x9edeeb91266f1f2453fbdd67cd00f3dff1575ced0 Ether
0x76a4facb45b3d91f6e5a657d0747fe8ddbb7486797875f53590d69a7fa96b7c7486837125 days 9 hrs ago0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0x9edeeb91266f1f2453fbdd67cd00f3dff1575ced0 Ether
0x5ea5f196b13dfca3c84223b667f15970b7431286cf1843df64a572df5f83ec7f486720325 days 15 hrs ago0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0x0b30df42e49d3906f0c50916d6e99727b58a86500.172 Ether
0x5ea5f196b13dfca3c84223b667f15970b7431286cf1843df64a572df5f83ec7f486720325 days 15 hrs ago0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0x5ef633ff6f33a161dff9963f17b0b0eab6e6451c0 Ether
0x5ea5f196b13dfca3c84223b667f15970b7431286cf1843df64a572df5f83ec7f486720325 days 15 hrs ago0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0x2ad2387607ae62884c99beb473f34dcdfacc5a3c0 Ether
0x5ea5f196b13dfca3c84223b667f15970b7431286cf1843df64a572df5f83ec7f486720325 days 15 hrs ago0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0x9edeeb91266f1f2453fbdd67cd00f3dff1575ced0 Ether
0x5ea5f196b13dfca3c84223b667f15970b7431286cf1843df64a572df5f83ec7f486720325 days 15 hrs ago0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0x9edeeb91266f1f2453fbdd67cd00f3dff1575ced0 Ether
0x5ea5f196b13dfca3c84223b667f15970b7431286cf1843df64a572df5f83ec7f486720325 days 15 hrs ago0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0x2ad2387607ae62884c99beb473f34dcdfacc5a3c0 Ether
0x5ea5f196b13dfca3c84223b667f15970b7431286cf1843df64a572df5f83ec7f486720325 days 15 hrs ago0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0x9edeeb91266f1f2453fbdd67cd00f3dff1575ced0 Ether
0x5ea5f196b13dfca3c84223b667f15970b7431286cf1843df64a572df5f83ec7f486720325 days 15 hrs ago0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0x9edeeb91266f1f2453fbdd67cd00f3dff1575ced0 Ether
0x488f51cc9aaf05dc8da6e6dd930300cc50c4d28fd0d0179cd4e44ab3d7092983486710925 days 15 hrs ago0xa7a8b1c9b519deccee933102e29bb8c8b269da4c0x0b30df42e49d3906f0c50916d6e99727b58a86500.172 Ether
[ Download CSV Export  ] 
Warning: The Compiled Contract might be susceptible to ExpExponentCleanup (medium/high-severity), EventStructWrongData (very low-severity) SolidityCompiler Bugs.

Contract Source Code Verified (Exact Match)
Contract Name: SignkeysCrowdsale
Compiler Version: v0.4.24+commit.e67f0147
Optimization Enabled: Yes
Runs (Optimiser):  200



  Contract Source Code   Find Similiar Contracts

pragma solidity ^0.4.24;

// File: openzeppelin-solidity/contracts/ownership/Ownable.sol

/**
 * @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 private _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() internal {
    _owner = msg.sender;
    emit OwnershipTransferred(address(0), _owner);
  }

  /**
   * @return the address of the owner.
   */
  function owner() public view returns(address) {
    return _owner;
  }

  /**
   * @dev Throws if called by any account other than the owner.
   */
  modifier onlyOwner() {
    require(isOwner());
    _;
  }

  /**
   * @return true if `msg.sender` is the owner of the contract.
   */
  function isOwner() public view returns(bool) {
    return msg.sender == _owner;
  }

  /**
   * @dev Allows the current owner to relinquish control of the contract.
   * @notice Renouncing to ownership will leave the contract without an owner.
   * It will not be possible to call the functions with the `onlyOwner`
   * modifier anymore.
   */
  function renounceOwnership() public onlyOwner {
    emit OwnershipTransferred(_owner, address(0));
    _owner = address(0);
  }

  /**
   * @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 {
    _transferOwnership(newOwner);
  }

  /**
   * @dev Transfers control of the contract to a newOwner.
   * @param newOwner The address to transfer ownership to.
   */
  function _transferOwnership(address newOwner) internal {
    require(newOwner != address(0));
    emit OwnershipTransferred(_owner, newOwner);
    _owner = newOwner;
  }
}

// File: openzeppelin-solidity/contracts/token/ERC20/IERC20.sol

/**
 * @title ERC20 interface
 * @dev see https://github.com/ethereum/EIPs/issues/20
 */
interface IERC20 {
  function totalSupply() external view returns (uint256);

  function balanceOf(address who) external view returns (uint256);

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

  function transfer(address to, uint256 value) external returns (bool);

  function approve(address spender, uint256 value)
    external returns (bool);

  function transferFrom(address from, address to, uint256 value)
    external returns (bool);

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

  event Approval(
    address indexed owner,
    address indexed spender,
    uint256 value
  );
}

// File: openzeppelin-solidity/contracts/token/ERC20/ERC20Detailed.sol

/**
 * @title ERC20Detailed token
 * @dev The decimals are only for visualization purposes.
 * All the operations are done using the smallest and indivisible token unit,
 * just as on Ethereum all the operations are done in wei.
 */
contract ERC20Detailed is IERC20 {
  string private _name;
  string private _symbol;
  uint8 private _decimals;

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

  /**
   * @return the name of the token.
   */
  function name() public view returns(string) {
    return _name;
  }

  /**
   * @return the symbol of the token.
   */
  function symbol() public view returns(string) {
    return _symbol;
  }

  /**
   * @return the number of decimals of the token.
   */
  function decimals() public view returns(uint8) {
    return _decimals;
  }
}

// File: openzeppelin-solidity/contracts/math/SafeMath.sol

/**
 * @title SafeMath
 * @dev Math operations with safety checks that revert on error
 */
library SafeMath {

  /**
  * @dev Multiplies two numbers, reverts on overflow.
  */
  function mul(uint256 a, uint256 b) internal pure returns (uint256) {
    // Gas optimization: this is cheaper than requiring 'a' not being zero, but the
    // benefit is lost if 'b' is also tested.
    // See: https://github.com/OpenZeppelin/openzeppelin-solidity/pull/522
    if (a == 0) {
      return 0;
    }

    uint256 c = a * b;
    require(c / a == b);

    return c;
  }

  /**
  * @dev Integer division of two numbers truncating the quotient, reverts on division by zero.
  */
  function div(uint256 a, uint256 b) internal pure returns (uint256) {
    require(b > 0); // Solidity only automatically asserts 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 Subtracts two numbers, reverts on overflow (i.e. if subtrahend is greater than minuend).
  */
  function sub(uint256 a, uint256 b) internal pure returns (uint256) {
    require(b <= a);
    uint256 c = a - b;

    return c;
  }

  /**
  * @dev Adds two numbers, reverts on overflow.
  */
  function add(uint256 a, uint256 b) internal pure returns (uint256) {
    uint256 c = a + b;
    require(c >= a);

    return c;
  }

  /**
  * @dev Divides two numbers and returns the remainder (unsigned integer modulo),
  * reverts when dividing by zero.
  */
  function mod(uint256 a, uint256 b) internal pure returns (uint256) {
    require(b != 0);
    return a % b;
  }
}

// File: openzeppelin-solidity/contracts/token/ERC20/ERC20.sol

/**
 * @title Standard ERC20 token
 *
 * @dev Implementation of the basic standard token.
 * https://github.com/ethereum/EIPs/blob/master/EIPS/eip-20.md
 * Originally based on code by FirstBlood: https://github.com/Firstbloodio/token/blob/master/smart_contract/FirstBloodToken.sol
 */
contract ERC20 is IERC20 {
  using SafeMath for uint256;

  mapping (address => uint256) private _balances;

  mapping (address => mapping (address => uint256)) private _allowed;

  uint256 private _totalSupply;

  /**
  * @dev Total number of tokens in existence
  */
  function totalSupply() public view returns (uint256) {
    return _totalSupply;
  }

  /**
  * @dev Gets the balance of the specified address.
  * @param owner The address to query 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];
  }

  /**
   * @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 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) {
    _transfer(msg.sender, 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) {
    require(spender != address(0));

    _allowed[msg.sender][spender] = value;
    emit Approval(msg.sender, spender, value);
    return true;
  }

  /**
   * @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(value <= _allowed[from][msg.sender]);

    _allowed[from][msg.sender] = _allowed[from][msg.sender].sub(value);
    _transfer(from, to, value);
    return true;
  }

  /**
   * @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 increaseAllowance(
    address spender,
    uint256 addedValue
  )
    public
    returns (bool)
  {
    require(spender != address(0));

    _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 decreaseAllowance(
    address spender,
    uint256 subtractedValue
  )
    public
    returns (bool)
  {
    require(spender != address(0));

    _allowed[msg.sender][spender] = (
      _allowed[msg.sender][spender].sub(subtractedValue));
    emit Approval(msg.sender, spender, _allowed[msg.sender][spender]);
    return true;
  }

  /**
  * @dev Transfer token for a specified addresses
  * @param from The address to transfer from.
  * @param to The address to transfer to.
  * @param value The amount to be transferred.
  */
  function _transfer(address from, address to, uint256 value) internal {
    require(value <= _balances[from]);
    require(to != address(0));

    _balances[from] = _balances[from].sub(value);
    _balances[to] = _balances[to].add(value);
    emit Transfer(from, to, value);
  }

  /**
   * @dev Internal function that mints an amount of the token and assigns it to
   * an account. This encapsulates the modification of balances such that the
   * proper events are emitted.
   * @param account The account that will receive the created tokens.
   * @param value The amount that will be created.
   */
  function _mint(address account, uint256 value) internal {
    require(account != 0);
    _totalSupply = _totalSupply.add(value);
    _balances[account] = _balances[account].add(value);
    emit Transfer(address(0), account, value);
  }

  /**
   * @dev Internal function that burns an amount of the token of a given
   * account.
   * @param account The account whose tokens will be burnt.
   * @param value The amount that will be burnt.
   */
  function _burn(address account, uint256 value) internal {
    require(account != 0);
    require(value <= _balances[account]);

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

  /**
   * @dev Internal function that burns an amount of the token of a given
   * account, deducting from the sender's allowance for said account. Uses the
   * internal burn function.
   * @param account The account whose tokens will be burnt.
   * @param value The amount that will be burnt.
   */
  function _burnFrom(address account, uint256 value) internal {
    require(value <= _allowed[account][msg.sender]);

    // Should https://github.com/OpenZeppelin/zeppelin-solidity/issues/707 be accepted,
    // this function needs to emit an event with the updated approval.
    _allowed[account][msg.sender] = _allowed[account][msg.sender].sub(
      value);
    _burn(account, value);
  }
}

// File: openzeppelin-solidity/contracts/access/Roles.sol

/**
 * @title Roles
 * @dev Library for managing addresses assigned to a Role.
 */
library Roles {
  struct Role {
    mapping (address => bool) bearer;
  }

  /**
   * @dev give an account access to this role
   */
  function add(Role storage role, address account) internal {
    require(account != address(0));
    require(!has(role, account));

    role.bearer[account] = true;
  }

  /**
   * @dev remove an account's access to this role
   */
  function remove(Role storage role, address account) internal {
    require(account != address(0));
    require(has(role, account));

    role.bearer[account] = false;
  }

  /**
   * @dev check if an account has this role
   * @return bool
   */
  function has(Role storage role, address account)
    internal
    view
    returns (bool)
  {
    require(account != address(0));
    return role.bearer[account];
  }
}

// File: openzeppelin-solidity/contracts/access/roles/PauserRole.sol

contract PauserRole {
  using Roles for Roles.Role;

  event PauserAdded(address indexed account);
  event PauserRemoved(address indexed account);

  Roles.Role private pausers;

  constructor() internal {
    _addPauser(msg.sender);
  }

  modifier onlyPauser() {
    require(isPauser(msg.sender));
    _;
  }

  function isPauser(address account) public view returns (bool) {
    return pausers.has(account);
  }

  function addPauser(address account) public onlyPauser {
    _addPauser(account);
  }

  function renouncePauser() public {
    _removePauser(msg.sender);
  }

  function _addPauser(address account) internal {
    pausers.add(account);
    emit PauserAdded(account);
  }

  function _removePauser(address account) internal {
    pausers.remove(account);
    emit PauserRemoved(account);
  }
}

// File: openzeppelin-solidity/contracts/lifecycle/Pausable.sol

/**
 * @title Pausable
 * @dev Base contract which allows children to implement an emergency stop mechanism.
 */
contract Pausable is PauserRole {
  event Paused(address account);
  event Unpaused(address account);

  bool private _paused;

  constructor() internal {
    _paused = false;
  }

  /**
   * @return true if the contract is paused, false otherwise.
   */
  function paused() public view returns(bool) {
    return _paused;
  }

  /**
   * @dev Modifier to make a function callable only when the contract is not paused.
   */
  modifier whenNotPaused() {
    require(!_paused);
    _;
  }

  /**
   * @dev Modifier to make a function callable only when the contract is paused.
   */
  modifier whenPaused() {
    require(_paused);
    _;
  }

  /**
   * @dev called by the owner to pause, triggers stopped state
   */
  function pause() public onlyPauser whenNotPaused {
    _paused = true;
    emit Paused(msg.sender);
  }

  /**
   * @dev called by the owner to unpause, returns to normal state
   */
  function unpause() public onlyPauser whenPaused {
    _paused = false;
    emit Unpaused(msg.sender);
  }
}

// File: openzeppelin-solidity/contracts/token/ERC20/ERC20Pausable.sol

/**
 * @title Pausable token
 * @dev ERC20 modified with pausable transfers.
 **/
contract ERC20Pausable is ERC20, Pausable {

  function transfer(
    address to,
    uint256 value
  )
    public
    whenNotPaused
    returns (bool)
  {
    return super.transfer(to, value);
  }

  function transferFrom(
    address from,
    address to,
    uint256 value
  )
    public
    whenNotPaused
    returns (bool)
  {
    return super.transferFrom(from, to, value);
  }

  function approve(
    address spender,
    uint256 value
  )
    public
    whenNotPaused
    returns (bool)
  {
    return super.approve(spender, value);
  }

  function increaseAllowance(
    address spender,
    uint addedValue
  )
    public
    whenNotPaused
    returns (bool success)
  {
    return super.increaseAllowance(spender, addedValue);
  }

  function decreaseAllowance(
    address spender,
    uint subtractedValue
  )
    public
    whenNotPaused
    returns (bool success)
  {
    return super.decreaseAllowance(spender, subtractedValue);
  }
}

// File: contracts/SignkeysToken.sol

contract SignkeysToken is ERC20Pausable, ERC20Detailed, Ownable {

    uint8 public constant DECIMALS = 18;

    uint256 public constant INITIAL_SUPPLY = 2E10 * (10 ** uint256(DECIMALS));

    /**
     * @dev Constructor that gives msg.sender all of existing tokens.
     */
    constructor() public ERC20Detailed("SignkeysToken", "KEYS", DECIMALS) {
        _mint(owner(), INITIAL_SUPPLY);
    }

    function approveAndCall(address _spender, uint256 _value, bytes _data) public payable returns (bool success) {
        require(_spender != address(this));
        require(super.approve(_spender, _value));
        require(_spender.call(_data));
        return true;
    }

    function() payable external {
        revert();
    }
}


/**
 * @title Helps contracts guard against reentrancy attacks.
 * @author Remco Bloemen <[email protected]π.com>, Eenae <[email protected]>
 * @dev If you mark a function `nonReentrant`, you should also
 * mark it `external`.
 */
contract ReentrancyGuard {

  /// @dev counter to allow mutex lock with only one SSTORE operation
  uint256 private _guardCounter;

  constructor() internal {
    // The counter starts at one to prevent changing it from zero to a non-zero
    // value, which is a more expensive operation.
    _guardCounter = 1;
  }

  /**
   * @dev Prevents a contract from calling itself, directly or indirectly.
   * Calling a `nonReentrant` function from another `nonReentrant`
   * function is not supported. It is possible to prevent this from happening
   * by making the `nonReentrant` function external, and make it call a
   * `private` function that does the actual work.
   */
  modifier nonReentrant() {
    _guardCounter += 1;
    uint256 localCounter = _guardCounter;
    _;
    require(localCounter == _guardCounter);
  }

}

contract SignkeysCrowdsale is Ownable, ReentrancyGuard {
    using SafeMath for uint256;

    /* Token contract */
    SignkeysToken public signkeysToken;

    /* Vesting contract */
    SignkeysVesting public signkeysVesting;

    /* Referral smart contract*/
    SignkeysReferral public referralSmartContract;

    /* signer address, can be set by owner only */
    address public signer;

    /* ETH funds will be transferred to this address */
    address public wallet;

    // Buyer bought the amount of tokens with tokenPrice
    event BuyTokens(
        address indexed buyer,
        address indexed tokenReceiver,
        uint256 tokenPrice,
        uint256 amount
    );

    // Wallet changed
    event WalletChanged(address newWallet);

    // Signer changed
    event CrowdsaleSignerChanged(address newSigner);

    constructor(
        address _token,
        address _vesting,
        address _referralSmartContract,
        address _wallet,
        address _signer
    ) public {
        require(_token != 0x0, "Token contract for crowdsale must be set");
        require(_vesting != 0x0, "Vesting contract for crowdsale must be set");
        require(_referralSmartContract != 0x0, "Referral smart contract for crowdsale must be set");

        require(_wallet != 0x0, "Wallet for fund transferring must be set");
        require(_signer != 0x0, "Signer must be set");

        signkeysToken = SignkeysToken(_token);
        signkeysVesting = SignkeysVesting(_vesting);
        referralSmartContract = SignkeysReferral(_referralSmartContract);

        signer = _signer;
        wallet = _wallet;
    }

    function setSignerAddress(address _signer) external onlyOwner {
        signer = _signer;
        emit CrowdsaleSignerChanged(_signer);
    }

    function setWalletAddress(address _wallet) external onlyOwner {
        wallet = _wallet;
        emit WalletChanged(_wallet);
    }

    function setVestingContract(address _vesting) external onlyOwner {
        signkeysVesting = SignkeysVesting(_vesting);
    }

    function setReferralSmartContract(address _referralSmartContract) external onlyOwner {
        referralSmartContract = SignkeysReferral(_referralSmartContract);
    }

    function getRemainingTokensToSell() external view returns (uint256) {
        return signkeysToken.balanceOf(this);
    }

    /**
     * @dev Make an investment.
     *
     * @param _tokenReceiver address where the tokens need to be transfered
     * @param _referral address of user that invited _tokenReceiver for this purchase
     * @param _tokenPrice price per one token including decimals
     * @param _minWei minimal amount of wei buyer should invest
     * @param _expiration expiration on token
     */
    function buyTokens(
        address _tokenReceiver,
        address _referral,
        uint256 _couponCampaignId, // starts with 1 if there is some, 0 means no coupon
        uint256 _tokenPrice,
        uint256 _minWei,
        uint256 _expiration,
        uint8 _v,
        bytes32 _r,
        bytes32 _s
    ) payable external nonReentrant {
        require(_expiration >= now, "Signature expired");
        require(_tokenReceiver != 0x0, "Token receiver must be provided");
        require(_minWei > 0, "Minimal amount to purchase must be greater than 0");

        require(wallet != 0x0, "Wallet must be set");
        require(msg.value >= _minWei, "Purchased amount is less than min amount to invest");

        address receivedSigner = ecrecover(
            keccak256(
                abi.encodePacked(
                    _tokenPrice, _minWei, _tokenReceiver, _referral, _couponCampaignId, _expiration
                )
            ), _v, _r, _s);

        require(receivedSigner == signer, "Something wrong with signature");

        uint256 tokensAmount = msg.value.mul(10 ** uint256(signkeysToken.decimals())).div(_tokenPrice);
        require(signkeysToken.balanceOf(this) >= tokensAmount, "Not enough tokens in sale contract");
        uint256 amountForVesting = tokensAmount.mul(signkeysVesting.percentageToLock()).div(100);

        signkeysToken.transfer(_tokenReceiver, tokensAmount.sub(amountForVesting));
        signkeysToken.approve(address(signkeysVesting), amountForVesting);
        signkeysVesting.lock(_tokenReceiver, amountForVesting);

        // send bonuses according to referral smart contract
        referralSmartContract.sendBonus(_referral, _tokenReceiver, tokensAmount, _couponCampaignId);

        // Pocket the money, or fail the crowdsale if we for some reason cannot send the money to our wallet
        wallet.transfer(msg.value);

        emit BuyTokens(msg.sender, _tokenReceiver, _tokenPrice, tokensAmount);
    }

    /**
     * Don't expect to just send in money and get tokens.
     */
    function() payable external {
        revert();
    }
}

contract SignkeysReferral is Ownable {
    using SafeMath for uint256;

    /* Token contract */
    SignkeysToken token;

    /* Crowdsale contract */
    SignkeysCrowdsale signkeysCrowdsale;

    /* How much bonuses to send according for the giver coupon campaign */
    mapping(uint256 => uint256) private _couponToBonuses;

    /* Check if referral already got the bonuses from the invited token receiver */
    mapping(address => bool) private _bonusToReferralWereSent;

    /* Check if coupon of the given campaign was used by the token receiver */
    mapping(address => mapping(uint256 => bool)) private _couponWereUsed;


    uint256[] public buyingAmountRanges = [199, 1000, 10000, 100000, 1000000, 10000000];
    uint256[] public referralRewards = [5, 50, 500, 5000, 50000];
    uint256[] public refereeRewards = [5, 50, 500, 5000, 50000];

    event BonusSent(
        address indexed referralAddress,
        uint256 referralAmount,
        address indexed refereeAddress,
        uint256 refereeAmount,
        uint256 cuponBonusAmount
    );

    constructor(address _token) public {
        token = SignkeysToken(_token);
    }

    function setCrowdsaleContract(address _crowdsale) public onlyOwner {
        signkeysCrowdsale = SignkeysCrowdsale(_crowdsale);
    }

    function addCouponCampaign(uint256 _couponCampaignId, uint256 amountOfBonuses) public onlyOwner {
        _couponToBonuses[_couponCampaignId] = amountOfBonuses;
    }

    function getCouponCampaign(uint256 _couponCampaignId) public view onlyOwner returns (uint256)  {
        return _couponToBonuses[_couponCampaignId];
    }

    function calcBonus(uint256 amount, bool isReferral) private view returns (uint256) {
        uint256 multiplier = 10 ** uint256(token.decimals());
        if (amount <= multiplier.mul(buyingAmountRanges[0])) {
            return 0;
        }
        for (uint i = 1; i < buyingAmountRanges.length; i++) {
            uint min = buyingAmountRanges[i - 1];
            uint max = buyingAmountRanges[i];
            if (amount > min.mul(multiplier) && amount <= max.mul(multiplier)) {
                return isReferral ? multiplier.mul(referralRewards[i - 1]) : multiplier.mul(refereeRewards[i - 1]);
            }
        }
    }

    function sendBonus(address referral, address referee, uint256 _amount, uint256 _couponCampaignId) external returns (uint256)  {
        require(msg.sender == address(signkeysCrowdsale), "Bonus may be sent only by crowdsale contract");

        uint256 referralBonus;
        uint256 refereeBonus;
        uint256 couponBonus;

        uint256 referralBonusAmount = calcBonus(_amount, true);
        uint256 refereeBonusAmount = calcBonus(_amount, false);

        if (
            referralBonusAmount > 0 &&
            referral != 0x0 &&
        !_bonusToReferralWereSent[referee] &&
        token.balanceOf(this) > referralBonusAmount) {
            token.transfer(referral, referralBonusAmount);
            _bonusToReferralWereSent[referee] = true;
            referralBonus = referralBonusAmount;
        } else {
            referralBonus = 0;
        }

        if (token.balanceOf(this) > refereeBonusAmount) {
            token.transfer(referee, refereeBonusAmount);
            refereeBonus = refereeBonusAmount;
        } else {
            refereeBonus = 0;
        }

        if (_couponCampaignId > 0 && !_couponWereUsed[referee][_couponCampaignId]) {
            if (token.balanceOf(this) > _couponToBonuses[_couponCampaignId]) {
                token.transfer(referee, _couponToBonuses[_couponCampaignId]);
                _couponWereUsed[referee][_couponCampaignId] = true;
                couponBonus = _couponToBonuses[_couponCampaignId];
            }else {
                couponBonus = 0;
            }
        }

        emit BonusSent(referral, referralBonus, referee, refereeBonus, couponBonus);
    }

    function getBuyingAmountRanges() public onlyOwner view returns (uint256[]) {
        return buyingAmountRanges;
    }

    function getReferralRewards() public onlyOwner view returns (uint256[]) {
        return referralRewards;
    }

    function getRefereeRewards() public onlyOwner view returns (uint256[]) {
        return refereeRewards;
    }

    function setBuyingAmountRanges(uint[] ranges) public onlyOwner {
        buyingAmountRanges = ranges;
    }

    function setReferralRewards(uint[] rewards) public onlyOwner {
        require(rewards.length == buyingAmountRanges.length - 1);
        referralRewards = rewards;
    }

    function setRefereeRewards(uint[] rewards) public onlyOwner {
        require(rewards.length == buyingAmountRanges.length - 1);
        refereeRewards = rewards;
    }
}


contract SignkeysVesting is Ownable {
    using SafeMath for uint256;

    uint256 public INITIAL_VESTING_CLIFF_SECONDS = 180 days;
    uint256 public INITIAL_PERCENTAGE_TO_LOCK = 50; // 50%

    // The token to which we add the vesting restrictions
    SignkeysToken public signkeysToken;

    // Crowdsale contract
    SignkeysCrowdsale public signkeysCrowdsale;

    // the start date of crowdsale
    uint public vestingStartDateTime;

    // the date after which user is able to sell all his tokens
    uint public vestingCliffDateTime;

    // the percentage of tokens to lock immediately after buying
    uint256 public percentageToLock;

    /* The amount of locked tokens for each user */
    mapping(address => uint256) private _balances;

    event TokensLocked(address indexed user, uint amount);
    event TokensReleased(address indexed user, uint amount);

    constructor() public{
        vestingStartDateTime = now;
        vestingCliffDateTime = SafeMath.add(now, INITIAL_VESTING_CLIFF_SECONDS);
        percentageToLock = INITIAL_PERCENTAGE_TO_LOCK;
    }

    function setToken(address token) external onlyOwner {
        signkeysToken = SignkeysToken(token);
    }

    function setCrowdsaleContract(address crowdsaleContract) external onlyOwner {
        signkeysCrowdsale = SignkeysCrowdsale(crowdsaleContract);
    }

    function balanceOf(address tokenHolder) external view returns (uint256) {
        return _balances[tokenHolder];
    }

    function lock(address _user, uint256 _amount) external returns (uint256)  {
        require(msg.sender == address(signkeysCrowdsale), "Tokens may be locked only by crowdsale contract");
        require(signkeysToken.balanceOf(_user) >= _amount, "User balance is less than the requested size");

        signkeysToken.transferFrom(msg.sender, this, _amount);

        _balances[_user] = _balances[_user].add(_amount);

        emit TokensLocked(_user, _amount);

        return _balances[_user];
    }

    /**
     * @notice Transfers vested tokens back to user.
     * @param _user user that asks to release his tokens
     */
    function release(address _user) private {
        require(vestingCliffDateTime <= now, "Cannot release vested tokens until vesting cliff date");
        uint256 unreleased = _balances[_user];

        if (unreleased > 0) {
            signkeysToken.transfer(_user, unreleased);
            _balances[_user] = _balances[_user].sub(unreleased);
        }

        emit TokensReleased(_user, unreleased);
    }

    function release() public {
        release(msg.sender);
    }

    function setVestingStartDateTime(uint _vestingStartDateTime) external onlyOwner {
        require(_vestingStartDateTime <= vestingCliffDateTime, "Start date should be less or equal than cliff date");
        vestingStartDateTime = _vestingStartDateTime;
    }

    function setVestingCliffDateTime(uint _vestingCliffDateTime) external onlyOwner {
        require(vestingStartDateTime <= _vestingCliffDateTime, "Cliff date should be greater or equal than start date");
        vestingCliffDateTime = _vestingCliffDateTime;
    }

    function setPercentageToLock(uint256 percentage) external onlyOwner {
        require(percentage >= 0 && percentage <= 100, "Percentage must be in range [0, 100]");
        percentageToLock = percentage;
    }
}

    Contract ABI  
[{"constant":false,"inputs":[{"name":"_signer","type":"address"}],"name":"setSignerAddress","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"signer","outputs":[{"name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"wallet","outputs":[{"name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[],"name":"renounceOwnership","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"_vesting","type":"address"}],"name":"setVestingContract","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"signkeysToken","outputs":[{"name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"_tokenReceiver","type":"address"},{"name":"_referral","type":"address"},{"name":"_couponCampaignId","type":"uint256"},{"name":"_tokenPrice","type":"uint256"},{"name":"_minWei","type":"uint256"},{"name":"_expiration","type":"uint256"},{"name":"_v","type":"uint8"},{"name":"_r","type":"bytes32"},{"name":"_s","type":"bytes32"}],"name":"buyTokens","outputs":[],"payable":true,"stateMutability":"payable","type":"function"},{"constant":true,"inputs":[],"name":"owner","outputs":[{"name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"isOwner","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"_wallet","type":"address"}],"name":"setWalletAddress","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"referralSmartContract","outputs":[{"name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"getRemainingTokensToSell","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"_referralSmartContract","type":"address"}],"name":"setReferralSmartContract","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":"signkeysVesting","outputs":[{"name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"inputs":[{"name":"_token","type":"address"},{"name":"_vesting","type":"address"},{"name":"_referralSmartContract","type":"address"},{"name":"_wallet","type":"address"},{"name":"_signer","type":"address"}],"payable":false,"stateMutability":"nonpayable","type":"constructor"},{"payable":true,"stateMutability":"payable","type":"fallback"},{"anonymous":false,"inputs":[{"indexed":true,"name":"buyer","type":"address"},{"indexed":true,"name":"tokenReceiver","type":"address"},{"indexed":false,"name":"tokenPrice","type":"uint256"},{"indexed":false,"name":"amount","type":"uint256"}],"name":"BuyTokens","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"name":"newWallet","type":"address"}],"name":"WalletChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"name":"newSigner","type":"address"}],"name":"CrowdsaleSignerChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"name":"previousOwner","type":"address"},{"indexed":true,"name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"}]

  Contract Creation Code Switch To Opcodes View
608060405234801561001057600080fd5b5060405160a0806114268339810160408181528251602084015191840151606085015160809095015160008054600160a060020a0319163317808255939694959294939192600160a060020a0392909216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a360018055600160a060020a038516151561012857604080517f08c379a000000000000000000000000000000000000000000000000000000000815260206004820152602860248201527f546f6b656e20636f6e747261637420666f722063726f776473616c65206d757360448201527f7420626520736574000000000000000000000000000000000000000000000000606482015290519081900360840190fd5b600160a060020a03841615156101c557604080517f08c379a000000000000000000000000000000000000000000000000000000000815260206004820152602a60248201527f56657374696e6720636f6e747261637420666f722063726f776473616c65206d60448201527f7573742062652073657400000000000000000000000000000000000000000000606482015290519081900360840190fd5b600160a060020a038316151561026257604080517f08c379a000000000000000000000000000000000000000000000000000000000815260206004820152603160248201527f526566657272616c20736d61727420636f6e747261637420666f722063726f7760448201527f6473616c65206d75737420626520736574000000000000000000000000000000606482015290519081900360840190fd5b600160a060020a03821615156102ff57604080517f08c379a000000000000000000000000000000000000000000000000000000000815260206004820152602860248201527f57616c6c657420666f722066756e64207472616e7366657272696e67206d757360448201527f7420626520736574000000000000000000000000000000000000000000000000606482015290519081900360840190fd5b600160a060020a038116151561037657604080517f08c379a000000000000000000000000000000000000000000000000000000000815260206004820152601260248201527f5369676e6572206d757374206265207365740000000000000000000000000000604482015290519081900360640190fd5b60028054600160a060020a0319908116600160a060020a0397881617909155600380548216958716959095179094556004805485169386169390931790925560058054841692851692909217909155600680549092169216919091179055611043806103e36000396000f3006080604052600436106100c15763ffffffff60e060020a600035041663046dc16681146100c6578063238ac933146100e9578063521eb2731461011a578063715018a61461012f5780637499156914610144578063849b2fe1146101655780638c6c83231461017a5780638da5cb5b146101ad5780638f32d59b146101c2578063ac1a386a146101eb578063b0a4a7e01461020c578063b9b8e25d14610221578063e2fb3d4a14610248578063f2fde38b14610269578063fd83ac111461028a575b600080fd5b3480156100d257600080fd5b506100e7600160a060020a036004351661029f565b005b3480156100f557600080fd5b506100fe610313565b60408051600160a060020a039092168252519081900360200190f35b34801561012657600080fd5b506100fe610322565b34801561013b57600080fd5b506100e7610331565b34801561015057600080fd5b506100e7600160a060020a036004351661039b565b34801561017157600080fd5b506100fe6103dd565b6100e7600160a060020a036004358116906024351660443560643560843560a43560ff60c4351660e435610104356103ec565b3480156101b957600080fd5b506100fe610d7e565b3480156101ce57600080fd5b506101d7610d8d565b604080519115158252519081900360200190f35b3480156101f757600080fd5b506100e7600160a060020a0360043516610d9e565b34801561021857600080fd5b506100fe610e12565b34801561022d57600080fd5b50610236610e21565b60408051918252519081900360200190f35b34801561025457600080fd5b506100e7600160a060020a0360043516610eb7565b34801561027557600080fd5b506100e7600160a060020a0360043516610ef9565b34801561029657600080fd5b506100fe610f18565b6102a7610d8d565b15156102b257600080fd5b60058054600160a060020a03831673ffffffffffffffffffffffffffffffffffffffff19909116811790915560408051918252517f1b1b9c288f2159b637e39a719c23512e9170a5f55d665e0ecf39daf1e24e962e9181900360200190a150565b600554600160a060020a031681565b600654600160a060020a031681565b610339610d8d565b151561034457600080fd5b60008054604051600160a060020a03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a36000805473ffffffffffffffffffffffffffffffffffffffff19169055565b6103a3610d8d565b15156103ae57600080fd5b6003805473ffffffffffffffffffffffffffffffffffffffff1916600160a060020a0392909216919091179055565b600254600160a060020a031681565b600180548101908190556000908190819042881015610455576040805160e560020a62461bcd02815260206004820152601160248201527f5369676e61747572652065787069726564000000000000000000000000000000604482015290519081900360640190fd5b600160a060020a038d1615156104b5576040805160e560020a62461bcd02815260206004820152601f60248201527f546f6b656e207265636569766572206d7573742062652070726f766964656400604482015290519081900360640190fd5b60008911610533576040805160e560020a62461bcd02815260206004820152603160248201527f4d696e696d616c20616d6f756e7420746f207075726368617365206d7573742060448201527f62652067726561746572207468616e2030000000000000000000000000000000606482015290519081900360840190fd5b600654600160a060020a03161515610595576040805160e560020a62461bcd02815260206004820152601260248201527f57616c6c6574206d757374206265207365740000000000000000000000000000604482015290519081900360640190fd5b34891115610613576040805160e560020a62461bcd02815260206004820152603260248201527f50757263686173656420616d6f756e74206973206c657373207468616e206d6960448201527f6e20616d6f756e7420746f20696e766573740000000000000000000000000000606482015290519081900360840190fd5b60018a8a8f8f8f8d6040516020018087815260200186815260200185600160a060020a0316600160a060020a03166c0100000000000000000000000002815260140184600160a060020a0316600160a060020a03166c0100000000000000000000000002815260140183815260200182815260200196505050505050506040516020818303038152906040526040518082805190602001908083835b602083106106ce5780518252601f1990920191602091820191016106af565b51815160209384036101000a60001901801990921691161790526040805192909401829003822060008084528383018087529190915260ff8f1683860152606083018e9052608083018d9052935160a08084019750919550601f1981019492819003909101925090865af115801561074a573d6000803e3d6000fd5b5050604051601f190151600554909550600160a060020a0380871691161490506107be576040805160e560020a62461bcd02815260206004820152601e60248201527f536f6d657468696e672077726f6e672077697468207369676e61747572650000604482015290519081900360640190fd5b6108638a610857600260009054906101000a9004600160a060020a0316600160a060020a031663313ce5676040518163ffffffff1660e060020a028152600401602060405180830381600087803b15801561081857600080fd5b505af115801561082c573d6000803e3d6000fd5b505050506040513d602081101561084257600080fd5b5051349060ff16600a0a63ffffffff610f2716565b9063ffffffff610f6016565b600254604080517f70a0823100000000000000000000000000000000000000000000000000000000815230600482015290519295508592600160a060020a03909216916370a08231916024808201926020929091908290030181600087803b1580156108ce57600080fd5b505af11580156108e2573d6000803e3d6000fd5b505050506040513d60208110156108f857600080fd5b50511015610976576040805160e560020a62461bcd02815260206004820152602260248201527f4e6f7420656e6f75676820746f6b656e7320696e2073616c6520636f6e74726160448201527f6374000000000000000000000000000000000000000000000000000000000000606482015290519081900360840190fd5b610a0a6064610857600360009054906101000a9004600160a060020a0316600160a060020a031663386b166e6040518163ffffffff1660e060020a028152600401602060405180830381600087803b1580156109d157600080fd5b505af11580156109e5573d6000803e3d6000fd5b505050506040513d60208110156109fb57600080fd5b5051869063ffffffff610f2716565b600254909250600160a060020a031663a9059cbb8e610a2f868663ffffffff610f8316565b6040518363ffffffff1660e060020a0281526004018083600160a060020a0316600160a060020a0316815260200182815260200192505050602060405180830381600087803b158015610a8157600080fd5b505af1158015610a95573d6000803e3d6000fd5b505050506040513d6020811015610aab57600080fd5b5050600254600354604080517f095ea7b3000000000000000000000000000000000000000000000000000000008152600160a060020a039283166004820152602481018690529051919092169163095ea7b39160448083019260209291908290030181600087803b158015610b1f57600080fd5b505af1158015610b33573d6000803e3d6000fd5b505050506040513d6020811015610b4957600080fd5b810190808051906020019092919050505050600360009054906101000a9004600160a060020a0316600160a060020a031663282d3fdf8e846040518363ffffffff1660e060020a0281526004018083600160a060020a0316600160a060020a0316815260200182815260200192505050602060405180830381600087803b158015610bd357600080fd5b505af1158015610be7573d6000803e3d6000fd5b505050506040513d6020811015610bfd57600080fd5b810190808051906020019092919050505050600460009054906101000a9004600160a060020a0316600160a060020a031663a981bb588d8f868f6040518563ffffffff1660e060020a0281526004018085600160a060020a0316600160a060020a0316815260200184600160a060020a0316600160a060020a03168152602001838152602001828152602001945050505050602060405180830381600087803b158015610ca957600080fd5b505af1158015610cbd573d6000803e3d6000fd5b505050506040513d6020811015610cd357600080fd5b5050600654604051600160a060020a03909116903480156108fc02916000818181858888f19350505050158015610d0e573d6000803e3d6000fd5b508c600160a060020a031633600160a060020a03167e77a7b9b8b8207f3903ca75eade7730a828eadd952909ed2de6b640b069fb178c86604051808381526020018281526020019250505060405180910390a36001548114610d6f57600080fd5b50505050505050505050505050565b600054600160a060020a031690565b600054600160a060020a0316331490565b610da6610d8d565b1515610db157600080fd5b60068054600160a060020a03831673ffffffffffffffffffffffffffffffffffffffff19909116811790915560408051918252517f3ce716f94fe275e52428cbf6b7f388e5a65976d4edabc34355a77f5e89655bdc9181900360200190a150565b600454600160a060020a031681565b600254604080517f70a082310000000000000000000000000000000000000000000000000000000081523060048201529051600092600160a060020a0316916370a0823191602480830192602092919082900301818787803b158015610e8657600080fd5b505af1158015610e9a573d6000803e3d6000fd5b505050506040513d6020811015610eb057600080fd5b5051905090565b610ebf610d8d565b1515610eca57600080fd5b6004805473ffffffffffffffffffffffffffffffffffffffff1916600160a060020a0392909216919091179055565b610f01610d8d565b1515610f0c57600080fd5b610f1581610f9a565b50565b600354600160a060020a031681565b600080831515610f3a5760009150610f59565b50828202828482811515610f4a57fe5b0414610f5557600080fd5b8091505b5092915050565b600080808311610f6f57600080fd5b8284811515610f7a57fe5b04949350505050565b60008083831115610f9357600080fd5b5050900390565b600160a060020a0381161515610faf57600080fd5b60008054604051600160a060020a03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a36000805473ffffffffffffffffffffffffffffffffffffffff1916600160a060020a03929092169190911790555600a165627a7a723058209044b175de6b0563745211430a5c3d77050386d3d7a3ea342cdc422b431959cc00290000000000000000000000009edeeb91266f1f2453fbdd67cd00f3dff1575ced0000000000000000000000002ad2387607ae62884c99beb473f34dcdfacc5a3c0000000000000000000000005ef633ff6f33a161dff9963f17b0b0eab6e6451c0000000000000000000000000b30df42e49d3906f0c50916d6e99727b58a86500000000000000000000000000b30df42e49d3906f0c50916d6e99727b58a8650

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

-----Encoded View---------------
5 Constructor Arguments found :
Arg [0] : 0000000000000000000000009edeeb91266f1f2453fbdd67cd00f3dff1575ced
Arg [1] : 0000000000000000000000002ad2387607ae62884c99beb473f34dcdfacc5a3c
Arg [2] : 0000000000000000000000005ef633ff6f33a161dff9963f17b0b0eab6e6451c
Arg [3] : 0000000000000000000000000b30df42e49d3906f0c50916d6e99727b58a8650
Arg [4] : 0000000000000000000000000b30df42e49d3906f0c50916d6e99727b58a8650


   Swarm Source:
bzzr://9044b175de6b0563745211430a5c3d77050386d3d7a3ea342cdc422b431959cc

 

View All
Block Age transaction Difficulty GasUsed Reward
View All
Block Age UncleNumber Difficulty GasUsed Reward