More Info
Private Name Tags
ContractCreator
Latest 25 from a total of 259 transactions
Transaction Hash |
Method
|
Block
|
From
|
To
|
|||||
---|---|---|---|---|---|---|---|---|---|
Transfer | 5008215 | 2582 days ago | IN | 0.025 ETH | 0.00230034 | ||||
Transfer | 5007918 | 2582 days ago | IN | 5.25 ETH | 0.00362804 | ||||
Transfer | 5007878 | 2582 days ago | IN | 2.7 ETH | 0.00223264 | ||||
Transfer | 5007851 | 2582 days ago | IN | 0.42 ETH | 0.00034885 | ||||
Transfer | 5007840 | 2582 days ago | IN | 0.032 ETH | 0.001564 | ||||
Transfer | 5007781 | 2582 days ago | IN | 0.1 ETH | 0.00362804 | ||||
Transfer | 5007735 | 2582 days ago | IN | 0.11 ETH | 0.0013954 | ||||
Transfer | 5007663 | 2582 days ago | IN | 0.37 ETH | 0.00362804 | ||||
Transfer | 5007574 | 2582 days ago | IN | 0.11483986 ETH | 0.00362804 | ||||
Transfer | 5007562 | 2582 days ago | IN | 0.14158151 ETH | 0.00146517 | ||||
Transfer | 5007465 | 2582 days ago | IN | 0.02 ETH | 0.00362804 | ||||
Transfer | 5007315 | 2582 days ago | IN | 0.2 ETH | 0.0013954 | ||||
Transfer | 5007155 | 2582 days ago | IN | 1 ETH | 0.00362804 | ||||
Transfer | 5006965 | 2583 days ago | IN | 0.487 ETH | 0.00153494 | ||||
Transfer | 5006658 | 2583 days ago | IN | 0.1 ETH | 0.00286057 | ||||
Transfer | 5006246 | 2583 days ago | IN | 0.01 ETH | 0.00286057 | ||||
Transfer | 5006140 | 2583 days ago | IN | 0.1 ETH | 0.00286057 | ||||
Transfer | 5006011 | 2583 days ago | IN | 0.1 ETH | 0.0013954 | ||||
Transfer | 5005884 | 2583 days ago | IN | 0.0892 ETH | 0.0013954 | ||||
Transfer | 5005456 | 2583 days ago | IN | 0.2 ETH | 0.0041862 | ||||
Transfer | 5005118 | 2583 days ago | IN | 0.1 ETH | 0.00362804 | ||||
Set Rate | 5005026 | 2583 days ago | IN | 0 ETH | 0.00058736 | ||||
Transfer | 5004869 | 2583 days ago | IN | 0.13 ETH | 0.00362804 | ||||
Transfer | 5004869 | 2583 days ago | IN | 0.11 ETH | 0.0041862 | ||||
Transfer | 5004461 | 2583 days ago | IN | 0.2 ETH | 0.00362804 |
Latest 25 internal transactions (View All)
Advanced mode:
Parent Transaction Hash | Block |
From
|
To
|
|||
---|---|---|---|---|---|---|
5008215 | 2582 days ago | 0.025 ETH | ||||
5007918 | 2582 days ago | 5.25 ETH | ||||
5007878 | 2582 days ago | 2.7 ETH | ||||
5007851 | 2582 days ago | 0.42 ETH | ||||
5007781 | 2582 days ago | 0.1 ETH | ||||
5007735 | 2582 days ago | 0.11 ETH | ||||
5007663 | 2582 days ago | 0.37 ETH | ||||
5007574 | 2582 days ago | 0.11483986 ETH | ||||
5007562 | 2582 days ago | 0.14158151 ETH | ||||
5007465 | 2582 days ago | 0.02 ETH | ||||
5007315 | 2582 days ago | 0.2 ETH | ||||
5007155 | 2582 days ago | 1 ETH | ||||
5006965 | 2583 days ago | 0.487 ETH | ||||
5006658 | 2583 days ago | 0.1 ETH | ||||
5006246 | 2583 days ago | 0.01 ETH | ||||
5006140 | 2583 days ago | 0.1 ETH | ||||
5006011 | 2583 days ago | 0.1 ETH | ||||
5005884 | 2583 days ago | 0.0892 ETH | ||||
5005456 | 2583 days ago | 0.2 ETH | ||||
5005118 | 2583 days ago | 0.1 ETH | ||||
5004869 | 2583 days ago | 0.13 ETH | ||||
5004869 | 2583 days ago | 0.11 ETH | ||||
5004461 | 2583 days ago | 0.2 ETH | ||||
5003801 | 2583 days ago | 0.095011 ETH | ||||
5002072 | 2583 days ago | 2.3 ETH |
Loading...
Loading
Contract Source Code Verified (Exact Match)
Contract Name:
NodeCrowdsale
Compiler Version
v0.4.19+commit.c4cbbb05
Optimization Enabled:
No with 200 runs
Other Settings:
default evmVersion
Contract Source Code (Solidity)
/** *Submitted for verification at Etherscan.io on 2018-01-15 */ pragma solidity ^0.4.18; /** * @title SafeMath * @dev Math operations with safety checks that throw on error */ library SafeMath { 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; } 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; } function sub(uint256 a, uint256 b) internal pure returns (uint256) { assert(b <= a); return a - b; } function add(uint256 a, uint256 b) internal pure 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) public view returns (uint256); function transfer(address to, uint256 value) public returns (bool); event Transfer(address indexed from, address indexed to, uint256 value); } /** * @title ERC20 interface * @dev see https://github.com/ethereum/EIPs/issues/20 */ contract ERC20 is ERC20Basic { function allowance(address owner, address spender) public view returns (uint256); function transferFrom(address from, address to, uint256 value) public returns (bool); function approve(address spender, uint256 value) public returns (bool); event Approval(address indexed owner, address indexed spender, uint256 value); } /** * @title Basic token * @dev Basic version of StandardToken, with no allowances. */ contract BasicToken is ERC20Basic { using SafeMath for uint256; mapping(address => uint256) balances; /** * @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]; } } /** * @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; } } contract NodeToken is StandardToken { string public name = "NodePower"; string public symbol = "NODE"; uint8 public decimals = 2; bool public mintingFinished = false; mapping (address => bool) owners; mapping (address => bool) minters; event Mint(address indexed to, uint256 amount); event MintFinished(); event OwnerAdded(address indexed newOwner); event OwnerRemoved(address indexed removedOwner); event MinterAdded(address indexed newMinter); event MinterRemoved(address indexed removedMinter); event Burn(address indexed burner, uint256 value); function NodeToken() public { owners[msg.sender] = true; } /** * @dev Function to mint tokens * @param _to The address that will receive 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) onlyMinter public returns (bool) { require(!mintingFinished); totalSupply = totalSupply.add(_amount); balances[_to] = balances[_to].add(_amount); Mint(_to, _amount); Transfer(address(0), _to, _amount); return true; } /** * @dev Function to stop minting new tokens. * @return True if the operation was successful. */ function finishMinting() onlyOwner public returns (bool) { require(!mintingFinished); mintingFinished = true; MintFinished(); return true; } /** * @dev Burns a specific amount of tokens. * @param _value The amount of token to be burned. */ function burn(uint256 _value) public { require(_value <= balances[msg.sender]); // no need to require value <= totalSupply, since that would imply the // sender's balance is greater than the totalSupply, which *should* be an assertion failure address burner = msg.sender; balances[burner] = balances[burner].sub(_value); totalSupply = totalSupply.sub(_value); Burn(burner, _value); } /** * @dev Adds administrative role to address * @param _address The address that will get administrative privileges */ function addOwner(address _address) onlyOwner public { owners[_address] = true; OwnerAdded(_address); } /** * @dev Removes administrative role from address * @param _address The address to remove administrative privileges from */ function delOwner(address _address) onlyOwner public { owners[_address] = false; OwnerRemoved(_address); } /** * @dev Throws if called by any account other than the owner. */ modifier onlyOwner() { require(owners[msg.sender]); _; } /** * @dev Adds minter role to address (able to create new tokens) * @param _address The address that will get minter privileges */ function addMinter(address _address) onlyOwner public { minters[_address] = true; MinterAdded(_address); } /** * @dev Removes minter role from address * @param _address The address to remove minter privileges */ function delMinter(address _address) onlyOwner public { minters[_address] = false; MinterRemoved(_address); } /** * @dev Throws if called by any account other than the minter. */ modifier onlyMinter() { require(minters[msg.sender]); _; } } /** * @title Crowdsale * @dev Crowdsale is a base contract for managing a token crowdsale. * Crowdsales have a start and end timestamps, where investors can make * token purchases and the crowdsale will assign them tokens based * on a token per ETH rate. Funds collected are forwarded to a wallet * as they arrive. */ contract NodeCrowdsale { using SafeMath for uint256; // The token being sold NodeToken public token; // address where funds are collected address public wallet; // address where funds are collected address public owner; // USD cents per ETH exchange rate uint256 public rateUSDcETH; // PreITO discount is 45% uint public constant bonusTokensPercent = 45; // PreITO ends on 2018-01-31 23:59:59 UTC uint256 public constant endTime = 1517443199; // Minimum Deposit in USD cents uint256 public constant minContributionUSDc = 1000; // amount of raised money in wei uint256 public weiRaised; /** * event for token purchase logging * @param purchaser who paid for the tokens * @param beneficiary who got the tokens * @param value weis paid for purchase * @param amount amount of tokens purchased */ event TokenPurchase(address indexed purchaser, address indexed beneficiary, uint256 value, uint256 amount); event RateUpdate(uint256 rate); function NodeCrowdsale(address _tokenAddress, uint256 _initialRate) public { require(_tokenAddress != address(0)); token = NodeToken(_tokenAddress); rateUSDcETH = _initialRate; wallet = msg.sender; owner = msg.sender; } // fallback function can be used to buy tokens function () external payable { buyTokens(msg.sender); } // low level token purchase function function buyTokens(address beneficiary) public payable { require(beneficiary != address(0)); require(msg.value != 0); require(now <= endTime); uint256 weiAmount = msg.value; require(calculateUSDcValue(weiAmount) >= minContributionUSDc); // calculate token amount to be created uint256 tokens = calculateTokenAmount(weiAmount); // update state weiRaised = weiRaised.add(weiAmount); token.mint(beneficiary, tokens); TokenPurchase(msg.sender, beneficiary, weiAmount, tokens); forwardFunds(); } // set rate function setRate(uint256 _rateUSDcETH) public onlyOwner { // don't allow to change rate more than 10% assert(_rateUSDcETH < rateUSDcETH.mul(110).div(100)); assert(_rateUSDcETH > rateUSDcETH.mul(90).div(100)); rateUSDcETH = _rateUSDcETH; RateUpdate(rateUSDcETH); } /** * @dev Throws if called by any account other than the owner. */ modifier onlyOwner() { require(msg.sender == owner); _; } // calculate deposit value in USD Cents function calculateUSDcValue(uint256 _weiDeposit) public view returns (uint256) { // wei per USD cent uint256 weiPerUSDc = 1 ether/rateUSDcETH; // Deposited value converted to USD cents uint256 depositValueInUSDc = _weiDeposit.div(weiPerUSDc); return depositValueInUSDc; } // calculates how much tokens will beneficiary get // for given amount of wei function calculateTokenAmount(uint256 _weiDeposit) public view returns (uint256) { uint256 mainTokens = calculateUSDcValue(_weiDeposit); uint256 bonusTokens = mainTokens.mul(bonusTokensPercent).div(100); return mainTokens.add(bonusTokens); } // send ether to the fund collection wallet // override to create custom fund forwarding mechanisms function forwardFunds() internal { wallet.transfer(msg.value); } }
Contract Security Audit
- No Contract Security Audit Submitted- Submit Audit Here
[{"constant":true,"inputs":[],"name":"minContributionUSDc","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"endTime","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"_rateUSDcETH","type":"uint256"}],"name":"setRate","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"weiRaised","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"wallet","outputs":[{"name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"name":"_weiDeposit","type":"uint256"}],"name":"calculateUSDcValue","outputs":[{"name":"","type":"uint256"}],"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":"_weiDeposit","type":"uint256"}],"name":"calculateTokenAmount","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"rateUSDcETH","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"bonusTokensPercent","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"beneficiary","type":"address"}],"name":"buyTokens","outputs":[],"payable":true,"stateMutability":"payable","type":"function"},{"constant":true,"inputs":[],"name":"token","outputs":[{"name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"inputs":[{"name":"_tokenAddress","type":"address"},{"name":"_initialRate","type":"uint256"}],"payable":false,"stateMutability":"nonpayable","type":"constructor"},{"payable":true,"stateMutability":"payable","type":"fallback"},{"anonymous":false,"inputs":[{"indexed":true,"name":"purchaser","type":"address"},{"indexed":true,"name":"beneficiary","type":"address"},{"indexed":false,"name":"value","type":"uint256"},{"indexed":false,"name":"amount","type":"uint256"}],"name":"TokenPurchase","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"name":"rate","type":"uint256"}],"name":"RateUpdate","type":"event"}]
Contract Creation Code
6060604052341561000f57600080fd5b6040516040806109ca83398101604052808051906020019091908051906020019091905050600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff161415151561007057600080fd5b816000806101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055508060038190555033600160006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555033600260006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555050506108808061014a6000396000f3006060604052600436106100ba576000357c0100000000000000000000000000000000000000000000000000000000900463ffffffff168063253f89b0146100c55780633197cbb6146100ee57806334fcf437146101175780634042b66f1461013a578063521eb27314610163578063688bf035146101b85780638da5cb5b146101ef578063a24bcf4614610244578063c49589bb1461027b578063daca5ce0146102a4578063ec8ac4d8146102cd578063fc0c546a146102fb575b6100c333610350565b005b34156100d057600080fd5b6100d8610556565b6040518082815260200191505060405180910390f35b34156100f957600080fd5b61010161055c565b6040518082815260200191505060405180910390f35b341561012257600080fd5b6101386004808035906020019091905050610564565b005b341561014557600080fd5b61014d610669565b6040518082815260200191505060405180910390f35b341561016e57600080fd5b61017661066f565b604051808273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390f35b34156101c357600080fd5b6101d96004808035906020019091905050610695565b6040518082815260200191505060405180910390f35b34156101fa57600080fd5b6102026106d1565b604051808273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390f35b341561024f57600080fd5b61026560048080359060200190919050506106f7565b6040518082815260200191505060405180910390f35b341561028657600080fd5b61028e61074c565b6040518082815260200191505060405180910390f35b34156102af57600080fd5b6102b7610752565b6040518082815260200191505060405180910390f35b6102f9600480803573ffffffffffffffffffffffffffffffffffffffff16906020019091905050610350565b005b341561030657600080fd5b61030e610757565b604051808273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390f35b600080600073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff161415151561038f57600080fd5b6000341415151561039f57600080fd5b635a72587f42111515156103b257600080fd5b3491506103e86103c183610695565b101515156103ce57600080fd5b6103d7826106f7565b90506103ee8260045461077c90919063ffffffff16565b6004819055506000809054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166340c10f1984836000604051602001526040518363ffffffff167c0100000000000000000000000000000000000000000000000000000000028152600401808373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200182815260200192505050602060405180830381600087803b15156104c057600080fd5b6102c65a03f115156104d157600080fd5b50505060405180519050508273ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff167f623b3804fa71d67900d064613da8f94b9617215ee90799290593e1745087ad188484604051808381526020018281526020019250505060405180910390a361055161079a565b505050565b6103e881565b635a72587f81565b600260009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff161415156105c057600080fd5b6105e960646105db606e6003546107fe90919063ffffffff16565b61083990919063ffffffff16565b811015156105f357fe5b61061c606461060e605a6003546107fe90919063ffffffff16565b61083990919063ffffffff16565b8111151561062657fe5b806003819055507f9b831dcbec52dfe52b187da18aae08651dfb726e9baf49d5d9eae6fa264db3a16003546040518082815260200191505060405180910390a150565b60045481565b600160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b6000806000600354670de0b6b3a76400008115156106af57fe5b0491506106c5828561083990919063ffffffff16565b90508092505050919050565b600260009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b600080600061070584610695565b915061072e6064610720602d856107fe90919063ffffffff16565b61083990919063ffffffff16565b9050610743818361077c90919063ffffffff16565b92505050919050565b60035481565b602d81565b6000809054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b600080828401905083811015151561079057fe5b8091505092915050565b600160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108fc349081150290604051600060405180830381858888f1935050505015156107fc57600080fd5b565b60008060008414156108135760009150610832565b828402905082848281151561082457fe5b0414151561082e57fe5b8091505b5092915050565b600080828481151561084757fe5b04905080915050929150505600a165627a7a723058200a33894d52199fe3180075e9b97570d96d3938b391c6e50b87f796270c37db820029000000000000000000000000ac956c72c262e5405a84dac655d5f3bea7ae953400000000000000000000000000000000000000000000000000000000000212f9
Deployed Bytecode
0x6060604052600436106100ba576000357c0100000000000000000000000000000000000000000000000000000000900463ffffffff168063253f89b0146100c55780633197cbb6146100ee57806334fcf437146101175780634042b66f1461013a578063521eb27314610163578063688bf035146101b85780638da5cb5b146101ef578063a24bcf4614610244578063c49589bb1461027b578063daca5ce0146102a4578063ec8ac4d8146102cd578063fc0c546a146102fb575b6100c333610350565b005b34156100d057600080fd5b6100d8610556565b6040518082815260200191505060405180910390f35b34156100f957600080fd5b61010161055c565b6040518082815260200191505060405180910390f35b341561012257600080fd5b6101386004808035906020019091905050610564565b005b341561014557600080fd5b61014d610669565b6040518082815260200191505060405180910390f35b341561016e57600080fd5b61017661066f565b604051808273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390f35b34156101c357600080fd5b6101d96004808035906020019091905050610695565b6040518082815260200191505060405180910390f35b34156101fa57600080fd5b6102026106d1565b604051808273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390f35b341561024f57600080fd5b61026560048080359060200190919050506106f7565b6040518082815260200191505060405180910390f35b341561028657600080fd5b61028e61074c565b6040518082815260200191505060405180910390f35b34156102af57600080fd5b6102b7610752565b6040518082815260200191505060405180910390f35b6102f9600480803573ffffffffffffffffffffffffffffffffffffffff16906020019091905050610350565b005b341561030657600080fd5b61030e610757565b604051808273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390f35b600080600073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff161415151561038f57600080fd5b6000341415151561039f57600080fd5b635a72587f42111515156103b257600080fd5b3491506103e86103c183610695565b101515156103ce57600080fd5b6103d7826106f7565b90506103ee8260045461077c90919063ffffffff16565b6004819055506000809054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166340c10f1984836000604051602001526040518363ffffffff167c0100000000000000000000000000000000000000000000000000000000028152600401808373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200182815260200192505050602060405180830381600087803b15156104c057600080fd5b6102c65a03f115156104d157600080fd5b50505060405180519050508273ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff167f623b3804fa71d67900d064613da8f94b9617215ee90799290593e1745087ad188484604051808381526020018281526020019250505060405180910390a361055161079a565b505050565b6103e881565b635a72587f81565b600260009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff161415156105c057600080fd5b6105e960646105db606e6003546107fe90919063ffffffff16565b61083990919063ffffffff16565b811015156105f357fe5b61061c606461060e605a6003546107fe90919063ffffffff16565b61083990919063ffffffff16565b8111151561062657fe5b806003819055507f9b831dcbec52dfe52b187da18aae08651dfb726e9baf49d5d9eae6fa264db3a16003546040518082815260200191505060405180910390a150565b60045481565b600160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b6000806000600354670de0b6b3a76400008115156106af57fe5b0491506106c5828561083990919063ffffffff16565b90508092505050919050565b600260009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b600080600061070584610695565b915061072e6064610720602d856107fe90919063ffffffff16565b61083990919063ffffffff16565b9050610743818361077c90919063ffffffff16565b92505050919050565b60035481565b602d81565b6000809054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b600080828401905083811015151561079057fe5b8091505092915050565b600160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108fc349081150290604051600060405180830381858888f1935050505015156107fc57600080fd5b565b60008060008414156108135760009150610832565b828402905082848281151561082457fe5b0414151561082e57fe5b8091505b5092915050565b600080828481151561084757fe5b04905080915050929150505600a165627a7a723058200a33894d52199fe3180075e9b97570d96d3938b391c6e50b87f796270c37db820029
Constructor Arguments (ABI-Encoded and is the last bytes of the Contract Creation Code above)
000000000000000000000000ac956c72c262e5405a84dac655d5f3bea7ae953400000000000000000000000000000000000000000000000000000000000212f9
-----Decoded View---------------
Arg [0] : _tokenAddress (address): 0xac956C72c262E5405A84dAc655d5f3Bea7Ae9534
Arg [1] : _initialRate (uint256): 135929
-----Encoded View---------------
2 Constructor Arguments found :
Arg [0] : 000000000000000000000000ac956c72c262e5405a84dac655d5f3bea7ae9534
Arg [1] : 00000000000000000000000000000000000000000000000000000000000212f9
Swarm Source
bzzr://0a33894d52199fe3180075e9b97570d96d3938b391c6e50b87f796270c37db82
Loading...
Loading
Loading...
Loading
Multichain Portfolio | 31 Chains
Chain | Token | Portfolio % | Price | Amount | Value |
---|
Loading...
Loading
[ Download: CSV Export ]
[ Download: CSV Export ]
A contract address hosts a smart contract, which is a set of code stored on the blockchain that runs when predetermined conditions are met. Learn more about addresses in our Knowledge Base.