Transaction Hash:
Block:
5305113 at Mar-23-2018 04:26:13 AM +UTC
Transaction Fee:
0.000054772 ETH
$0.14
Gas Used:
27,386 Gas / 2 Gwei
Emitted Events:
84 |
NANJCOIN.Transfer( 0xe19260aff97b920c7df27010903aeb9c8d2be5d310a2c67824cf3f15396e4c16, 0x00000000000000000000000014c2408a8c242d45d48e519363f862eea0c55c87, 0x000000000000000000000000e6c2d451936dfca11fa968426b93e70f8a135221, 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470, 000000000000000000000000000000000000000000000000000001d1a94a2000 )
|
85 |
NANJCOIN.Transfer( _from=[Sender] 0x14c2408a8c242d45d48e519363f862eea0c55c87, _to=0xE6c2d451936dFCA11fa968426b93E70F8A135221, _value=2000000000000 )
|
Account State Difference:
Address | Before | After | State Difference | ||
---|---|---|---|---|---|
0x14C2408a...Ea0c55c87 |
0.0005 Eth
Nonce: 0
|
0.000445228 Eth
Nonce: 1
| 0.000054772 | ||
0x5A0b54D5...D3E029c4c
Miner
| (Spark Pool) | 4,208.998701554175748933 Eth | 4,208.998756326175748933 Eth | 0.000054772 | |
0xFFE02ee4...7a7b9e265 |
Execution Trace
NANJCOIN.transfer( _to=0xE6c2d451936dFCA11fa968426b93E70F8A135221, _value=2000000000000 ) => ( success=True )
transfer[NANJCOIN (ln:310)]
isContract[NANJCOIN (ln:317)]
sub[NANJCOIN (ln:319)]
add[NANJCOIN (ln:320)]
value[NANJCOIN (ln:321)]
Transfer[NANJCOIN (ln:322)]
Transfer[NANJCOIN (ln:323)]
transferToAddress[NANJCOIN (ln:326)]
sub[NANJCOIN (ln:376)]
add[NANJCOIN (ln:377)]
Transfer[NANJCOIN (ln:378)]
Transfer[NANJCOIN (ln:379)]
pragma solidity ^0.4.18; /* __ __ ______ __ __ _____ ______ ______ ______ __ __ * / \ / | / \ / \ / | / | / \ / \ / |/ \ / | * $$ \ $$ |/$$$$$$ |$$ \ $$ | $$$$$ | /$$$$$$ |/$$$$$$ |$$$$$$/ $$ \ $$ | * $$$ \$$ |$$ |__$$ |$$$ \$$ | $$ | $$ | $$/ $$ | $$ | $$ | $$$ \$$ | * $$$$ $$ |$$ $$ |$$$$ $$ | __ $$ | $$ | $$ | $$ | $$ | $$$$ $$ | * $$ $$ $$ |$$$$$$$$ |$$ $$ $$ |/ | $$ | $$ | __ $$ | $$ | $$ | $$ $$ $$ | * $$ |$$$$ |$$ | $$ |$$ |$$$$ |$$ \__$$ | $$ \__/ |$$ \__$$ | _$$ |_ $$ |$$$$ | * $$ | $$$ |$$ | $$ |$$ | $$$ |$$ $$/ $$ $$/ $$ $$/ / $$ |$$ | $$$ | * $$/ $$/ $$/ $$/ $$/ $$/ $$$$$$/ $$$$$$/ $$$$$$/ $$$$$$/ $$/ $$/ */ // JJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJ // JJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJ // JJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJ JJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJ // JJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJ JJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJ // JJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJ JJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJ // JJJJJJJJJJJJJJJJJJJJJJJJJJJJJ JJJJJJJJJJJJJJJJJJJJJJJJJJJJJ // JJJJJJJJJJJJJJJJJJJJJJJJJJ JJJJJJJJJJJJJJJJJJJJJJJJJJ // JJJJJJJJJJJJJJJJJJJJJJ JJJJJJJJJJJJJJJJJJJJJJ // JJJJJJJJJJJJJJJJJJJ JJJJJJJJJJJJJJJJJJJ // JJJJJJJJJJJJJJJJJ] JJJJJ [JJJJJJJJJJJJJJJJJ // JJJJJJJJJJJJJJJJJ] JJJJJJ [JJJJJJJJJJJJJJJJJ // JJJJJJJJJJJJJJJJJ] JJJJJJ [JJJJJJJJJJJJJJJJJ // JJJJJJJJJJJJJJJJJ] JJJJJJ [JJJJJJJJJJJJJJJJJ // JJJJJJJJJJJJJJJJJ] JJJJJJ [JJJJJJJJJJJJJJJJJ // JJJJJJJJJJJJJJJJJ] , JJJJJJ [JJJJJJJJJJJJJJJJJ // JJJJJJJJJJJJJJJJJ] NN NN AA NN NN JJJJJJ [JJJJJJJJJJJJJJJJJ // JJJJJJJJJJJJJJJJJ] NNNN NN A A NNNN NN JJJJJJ [JJJJJJJJJJJJJJJJJ // JJJJJJJJJJJJJJJJJ] NN NNNN AAAAAA NN NNNN JJJJJJ [JJJJJJJJJJJJJJJJJ // JJJJJJJJJJJJJJJJJ] NN NN AA AA NN NN JJJJJJ [JJJJJJJJJJJJJJJJJ // JJJJJJJJJJJJJJJJJ] JJJJJJ [JJJJJJJJJJJJJJJJJ // JJJJJJJJJJJJJJJJJ] JJJJJJ [JJJJJJJJJJJJJJJJJ // JJJJJJJJJJJJJJJJJ] JJJJJJJ [JJJJJJJJJJJJJJJJJ // JJJJJJJJJJJJJJJJJ] JJJJJJJJJJJ [JJJJJJJJJJJJJJJJJ // JJJJJJJJJJJJJJJJJ] JJJJJJJJJJJJJJ [JJJJJJJJJJJJJJJJJ // JJJJJJJJJJJJJJJJJJ JJJJJJJJJJJJJJ JJJJJJJJJJJJJJJJJJ // JJJJJJJJJJJJJJJJJJJ JJJJJJJJJJJJJJJ JJJJJJJJJJJJJJJJJJJJ // JJJJJJJJJJJJJJJJJJJJJJ JJJJJJJJJJJ JJJJJJJJJJJJJJJJJJJJJJJ // JJJJJJJJJJJJJJJJJJJJJJJJJJ JJJJJJJ JJJJJJJJJJJJJJJJJJJJJJJJJJ // JJJJJJJJJJJJJJJJJJJJJJJJJJJJJ JJJ JJJJJJJJJJJJJJJJJJJJJJJJJJJJJ // JJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJ JJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJ // JJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJ JJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJ // JJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJ JJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJ // JJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJ // JJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJ /** * @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 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) onlyOwner public { require(newOwner != address(0)); OwnershipTransferred(owner, newOwner); owner = newOwner; } } /** * 彡(^)(^) * @title ERC223 * @dev ERC223 contract interface with ERC20 functions and events * Fully backward compatible with ERC20 * Recommended implementation used at https://github.com/Dexaran/ERC223-token-standard/tree/Recommended */ contract ERC223 { uint public totalSupply; // ERC223 and ERC20 functions and events function balanceOf(address who) public view returns (uint); function totalSupply() public view returns (uint256 _supply); function transfer(address to, uint value) public returns (bool ok); function transfer(address to, uint value, bytes data) public returns (bool ok); function transfer(address to, uint value, bytes data, string customFallback) public returns (bool ok); event Transfer(address indexed from, address indexed to, uint value, bytes indexed data); // ERC223 functions function name() public view returns (string _name); function symbol() public view returns (string _symbol); function decimals() public view returns (uint8 _decimals); // ERC20 functions and events function transferFrom(address _from, address _to, uint256 _value) public returns (bool success); function approve(address _spender, uint256 _value) public returns (bool success); function allowance(address _owner, address _spender) public view returns (uint256 remaining); event Transfer(address indexed _from, address indexed _to, uint256 _value); event Approval(address indexed _owner, address indexed _spender, uint _value); } /** * @title ContractReceiver * @dev Contract that is working with ERC223 tokens */ contract ContractReceiver { struct TKN { address sender; uint value; bytes data; bytes4 sig; } function tokenFallback(address _from, uint _value, bytes _data) public pure { TKN memory tkn; tkn.sender = _from; tkn.value = _value; tkn.data = _data; uint32 u = uint32(_data[3]) + (uint32(_data[2]) << 8) + (uint32(_data[1]) << 16) + (uint32(_data[0]) << 24); tkn.sig = bytes4(u); /* * tkn variable is analogue of msg variable of Ether transaction * tkn.sender is person who initiated this token transaction (analogue of msg.sender) * tkn.value the number of tokens that were sent (analogue of msg.value) * tkn.data is data of token transaction (analogue of msg.data) * tkn.sig is 4 bytes signature of function if data of token transaction is a function execution */ } } /************************* * * `_ (三| * |ヒ_) / ̄ ̄\ LニO * | | /●) (●) \|| * |_|( (_人_) )^亅 * | ヽ\  ̄ _/ ミノ * ヽノノ ̄|レ―-イ / ノ / * \ ヽ\ |/ イ * / ̄二二二二二二\ * `|答| N A N J || * \_二二二二二二/ * *************************/ /** * 彡(゚)(゚) * @title NANJCOIN * @author Tsuchinoko & NanJ people * @dev NANJCOIN is an ERC223 Token with ERC20 functions and events * Fully backward compatible with ERC20 */ contract NANJCOIN is ERC223, Ownable { using SafeMath for uint256; string public name = "NANJCOIN"; string public symbol = "NANJ"; string public constant AAcontributors = "sybit & クリプたん"; uint8 public decimals = 8; uint256 public totalSupply = 30e9 * 1e8; uint256 public distributeAmount = 0; bool public mintingFinished = false; address public founder = 0x1B746E35C90050E3cc236479051467F623CA14f7; address public preSeasonGame = 0xAeC7cF1da46a76ad3A41580e28E778ff8849ec49; address public activityFunds = 0x728899556c836ce7F8AA73e8BaCE3241F17077bF; address public lockedFundsForthefuture = 0xB80c43bf83f7Cb6c44b84B436b01Ea92Da5dabFF; mapping(address => uint256) public balanceOf; mapping(address => mapping (address => uint256)) public allowance; mapping (address => bool) public frozenAccount; mapping (address => uint256) public unlockUnixTime; event FrozenFunds(address indexed target, bool frozen); event LockedFunds(address indexed target, uint256 locked); event Burn(address indexed from, uint256 amount); event Mint(address indexed to, uint256 amount); event MintFinished(); /** * @dev Constructor is called only once and can not be called again */ function NANJCOIN() public { owner = activityFunds; balanceOf[founder] = totalSupply.mul(25).div(100); balanceOf[preSeasonGame] = totalSupply.mul(55).div(100); balanceOf[activityFunds] = totalSupply.mul(10).div(100); balanceOf[lockedFundsForthefuture] = totalSupply.mul(10).div(100); } function name() public view returns (string _name) { return name; } function symbol() public view returns (string _symbol) { return symbol; } function decimals() public view returns (uint8 _decimals) { return decimals; } function totalSupply() public view returns (uint256 _totalSupply) { return totalSupply; } function balanceOf(address _owner) public view returns (uint256 balance) { return balanceOf[_owner]; } /** * @dev Prevent targets from sending or receiving tokens * @param targets Addresses to be frozen * @param isFrozen either to freeze it or not */ function freezeAccounts(address[] targets, bool isFrozen) onlyOwner public { require(targets.length > 0); for (uint j = 0; j < targets.length; j++) { require(targets[j] != 0x0); frozenAccount[targets[j]] = isFrozen; FrozenFunds(targets[j], isFrozen); } } /** * @dev Prevent targets from sending or receiving tokens by setting Unix times * @param targets Addresses to be locked funds * @param unixTimes Unix times when locking up will be finished */ function lockupAccounts(address[] targets, uint[] unixTimes) onlyOwner public { require(targets.length > 0 && targets.length == unixTimes.length); for(uint j = 0; j < targets.length; j++){ require(unlockUnixTime[targets[j]] < unixTimes[j]); unlockUnixTime[targets[j]] = unixTimes[j]; LockedFunds(targets[j], unixTimes[j]); } } /** * @dev Function that is called when a user or another contract wants to transfer funds */ function transfer(address _to, uint _value, bytes _data, string _custom_fallback) public returns (bool success) { require(_value > 0 && frozenAccount[msg.sender] == false && frozenAccount[_to] == false && now > unlockUnixTime[msg.sender] && now > unlockUnixTime[_to]); if (isContract(_to)) { require(balanceOf[msg.sender] >= _value); balanceOf[msg.sender] = balanceOf[msg.sender].sub(_value); balanceOf[_to] = balanceOf[_to].add(_value); assert(_to.call.value(0)(bytes4(keccak256(_custom_fallback)), msg.sender, _value, _data)); Transfer(msg.sender, _to, _value, _data); Transfer(msg.sender, _to, _value); return true; } else { return transferToAddress(_to, _value, _data); } } function transfer(address _to, uint _value, bytes _data) public returns (bool success) { require(_value > 0 && frozenAccount[msg.sender] == false && frozenAccount[_to] == false && now > unlockUnixTime[msg.sender] && now > unlockUnixTime[_to]); if (isContract(_to)) { return transferToContract(_to, _value, _data); } else { return transferToAddress(_to, _value, _data); } } /** * @dev Standard function transfer similar to ERC20 transfer with no _data * Added due to backwards compatibility reasons */ function transfer(address _to, uint _value) public returns (bool success) { require(_value > 0 && frozenAccount[msg.sender] == false && frozenAccount[_to] == false && now > unlockUnixTime[msg.sender] && now > unlockUnixTime[_to]); bytes memory empty; if (isContract(_to)) { return transferToContract(_to, _value, empty); } else { return transferToAddress(_to, _value, empty); } } // assemble the given address bytecode. If bytecode exists then the _addr is a contract. function isContract(address _addr) private view returns (bool is_contract) { uint length; assembly { //retrieve the size of the code on target address, this needs assembly length := extcodesize(_addr) } return (length > 0); } // function that is called when transaction target is an address function transferToAddress(address _to, uint _value, bytes _data) private returns (bool success) { require(balanceOf[msg.sender] >= _value); balanceOf[msg.sender] = balanceOf[msg.sender].sub(_value); balanceOf[_to] = balanceOf[_to].add(_value); Transfer(msg.sender, _to, _value, _data); Transfer(msg.sender, _to, _value); return true; } // function that is called when transaction target is a contract function transferToContract(address _to, uint _value, bytes _data) private returns (bool success) { require(balanceOf[msg.sender] >= _value); balanceOf[msg.sender] = balanceOf[msg.sender].sub(_value); balanceOf[_to] = balanceOf[_to].add(_value); ContractReceiver receiver = ContractReceiver(_to); receiver.tokenFallback(msg.sender, _value, _data); Transfer(msg.sender, _to, _value, _data); Transfer(msg.sender, _to, _value); return true; } /** * @dev Transfer tokens from one address to another * Added due to backwards compatibility with ERC20 * @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 success) { require(_to != address(0) && _value > 0 && balanceOf[_from] >= _value && allowance[_from][msg.sender] >= _value && frozenAccount[_from] == false && frozenAccount[_to] == false && now > unlockUnixTime[_from] && now > unlockUnixTime[_to]); balanceOf[_from] = balanceOf[_from].sub(_value); balanceOf[_to] = balanceOf[_to].add(_value); allowance[_from][msg.sender] = allowance[_from][msg.sender].sub(_value); Transfer(_from, _to, _value); return true; } /** * @dev Allows _spender to spend no more than _value tokens in your behalf * Added due to backwards compatibility with ERC20 * @param _spender The address authorized to spend * @param _value the max amount they can spend */ function approve(address _spender, uint256 _value) public returns (bool success) { allowance[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 * Added due to backwards compatibility with ERC20 * @param _owner address The address which owns the funds * @param _spender address The address which will spend the funds */ function allowance(address _owner, address _spender) public view returns (uint256 remaining) { return allowance[_owner][_spender]; } /** * @dev Burns a specific amount of tokens. * @param _from The address that will burn the tokens. * @param _unitAmount The amount of token to be burned. */ function burn(address _from, uint256 _unitAmount) onlyOwner public { require(_unitAmount > 0 && balanceOf[_from] >= _unitAmount); balanceOf[_from] = balanceOf[_from].sub(_unitAmount); totalSupply = totalSupply.sub(_unitAmount); Burn(_from, _unitAmount); } modifier canMint() { require(!mintingFinished); _; } /** * @dev Function to mint tokens * @param _to The address that will receive the minted tokens. * @param _unitAmount The amount of tokens to mint. */ function mint(address _to, uint256 _unitAmount) onlyOwner canMint public returns (bool) { require(_unitAmount > 0); totalSupply = totalSupply.add(_unitAmount); balanceOf[_to] = balanceOf[_to].add(_unitAmount); Mint(_to, _unitAmount); Transfer(address(0), _to, _unitAmount); return true; } /** * @dev Function to stop minting new tokens. */ function finishMinting() onlyOwner canMint public returns (bool) { mintingFinished = true; MintFinished(); return true; } /** * @dev Function to distribute tokens to the list of addresses by the provided amount */ function distributeAirdrop(address[] addresses, uint256 amount) public returns (bool) { require(amount > 0 && addresses.length > 0 && frozenAccount[msg.sender] == false && now > unlockUnixTime[msg.sender]); amount = amount.mul(1e8); uint256 totalAmount = amount.mul(addresses.length); require(balanceOf[msg.sender] >= totalAmount); for (uint j = 0; j < addresses.length; j++) { require(addresses[j] != 0x0 && frozenAccount[addresses[j]] == false && now > unlockUnixTime[addresses[j]]); balanceOf[addresses[j]] = balanceOf[addresses[j]].add(amount); Transfer(msg.sender, addresses[j], amount); } balanceOf[msg.sender] = balanceOf[msg.sender].sub(totalAmount); return true; } function distributeAirdrop(address[] addresses, uint[] amounts) public returns (bool) { require(addresses.length > 0 && addresses.length == amounts.length && frozenAccount[msg.sender] == false && now > unlockUnixTime[msg.sender]); uint256 totalAmount = 0; for(uint j = 0; j < addresses.length; j++){ require(amounts[j] > 0 && addresses[j] != 0x0 && frozenAccount[addresses[j]] == false && now > unlockUnixTime[addresses[j]]); amounts[j] = amounts[j].mul(1e8); totalAmount = totalAmount.add(amounts[j]); } require(balanceOf[msg.sender] >= totalAmount); for (j = 0; j < addresses.length; j++) { balanceOf[addresses[j]] = balanceOf[addresses[j]].add(amounts[j]); Transfer(msg.sender, addresses[j], amounts[j]); } balanceOf[msg.sender] = balanceOf[msg.sender].sub(totalAmount); return true; } /** * @dev Function to collect tokens from the list of addresses */ function collectTokens(address[] addresses, uint[] amounts) onlyOwner public returns (bool) { require(addresses.length > 0 && addresses.length == amounts.length); uint256 totalAmount = 0; for (uint j = 0; j < addresses.length; j++) { require(amounts[j] > 0 && addresses[j] != 0x0 && frozenAccount[addresses[j]] == false && now > unlockUnixTime[addresses[j]]); amounts[j] = amounts[j].mul(1e8); require(balanceOf[addresses[j]] >= amounts[j]); balanceOf[addresses[j]] = balanceOf[addresses[j]].sub(amounts[j]); totalAmount = totalAmount.add(amounts[j]); Transfer(addresses[j], msg.sender, amounts[j]); } balanceOf[msg.sender] = balanceOf[msg.sender].add(totalAmount); return true; } function setDistributeAmount(uint256 _unitAmount) onlyOwner public { distributeAmount = _unitAmount; } /** * @dev Function to distribute tokens to the msg.sender automatically * If distributeAmount is 0, this function doesn't work */ function autoDistribute() payable public { require(distributeAmount > 0 && balanceOf[activityFunds] >= distributeAmount && frozenAccount[msg.sender] == false && now > unlockUnixTime[msg.sender]); if(msg.value > 0) activityFunds.transfer(msg.value); balanceOf[activityFunds] = balanceOf[activityFunds].sub(distributeAmount); balanceOf[msg.sender] = balanceOf[msg.sender].add(distributeAmount); Transfer(activityFunds, msg.sender, distributeAmount); } /** * @dev fallback function */ function() payable public { autoDistribute(); } } /* *(`・ω・)(`・ω・´)(・ω・´) * Created by Tsuchinoko *(´・ω・)(´・ω・`)(・ω・`) */