Transaction Hash:
Block:
9484014 at Feb-14-2020 11:01:14 PM +UTC
Transaction Fee:
0.000283005 ETH
$0.93
Gas Used:
37,734 Gas / 7.5 Gwei
Emitted Events:
| 55 |
EKT.Transfer( _from=[Sender] 0x6582617d5e8ef846d5ef1425ab69b575d5e006d2, _to=0xC95215845db04b2A71e3C7d6858C91837aEe05C9, _value=1000000000 )
|
Account State Difference:
| Address | Before | After | State Difference | ||
|---|---|---|---|---|---|
| 0x6582617d...5d5E006D2 |
0.003799165 Eth
Nonce: 8
|
0.00351616 Eth
Nonce: 9
| 0.000283005 | ||
| 0xBAb165dF...1DDadB4c8 | |||||
|
0xEA674fdD...16B898ec8
Miner
| (Ethermine) | 779.225894535048209645 Eth | 779.226177540048209645 Eth | 0.000283005 |
Execution Trace
EKT.transfer( _to=0xC95215845db04b2A71e3C7d6858C91837aEe05C9, _value=1000000000 ) => ( success=True )
transfer[EKT (ln:61)]
Transfer[EKT (ln:70)]
pragma solidity ^0.4.16;
contract EKT {
string public name = "EDUCare"; // token name
string public symbol = "EKT"; // token symbol
uint256 public decimals = 8; // token digit
mapping (address => uint256) public balanceOf;
mapping (address => mapping (address => uint256)) public allowance;
uint256 public totalSupply = 0;
address owner = 0x0;
uint256 constant valueTotal = 10 * 10000 * 10000 * 100000000; //总量 10亿
uint256 constant valueFounder = valueTotal / 100 * 50; // 基金会50%
uint256 constant valueSale = valueTotal / 100 * 15; // ICO 15%
uint256 constant valueVip = valueTotal / 100 * 20; // 私募 20%
uint256 constant valueTeam = valueTotal / 100 * 15; // 团队与合作伙伴 15%
modifier isOwner {
assert(owner == msg.sender);
_;
}
modifier validAddress(address _address) {
assert(0x0 != _address);
_;
}
function EKT(address _founder, address _sale, address _vip, address _team)
public
validAddress(_founder)
validAddress(_sale)
validAddress(_vip)
validAddress(_team)
{
owner = msg.sender;
totalSupply = valueTotal;
// 基金会
balanceOf[_founder] = valueFounder;
Transfer(0x0, _founder, valueFounder);
// ICO
balanceOf[_sale] = valueSale;
Transfer(0x0, _sale, valueSale);
// 私募
balanceOf[_vip] = valueVip;
Transfer(0x0, _vip, valueVip);
// 团队
balanceOf[_team] = valueTeam;
Transfer(0x0, _team, valueTeam);
}
function transfer(address _to, uint256 _value)
public
validAddress(_to)
returns (bool success)
{
require(balanceOf[msg.sender] >= _value);
require(balanceOf[_to] + _value >= balanceOf[_to]);
balanceOf[msg.sender] -= _value;
balanceOf[_to] += _value;
Transfer(msg.sender, _to, _value);
return true;
}
function transferFrom(address _from, address _to, uint256 _value)
public
validAddress(_from)
validAddress(_to)
returns (bool success)
{
require(balanceOf[_from] >= _value);
require(balanceOf[_to] + _value >= balanceOf[_to]);
require(allowance[_from][msg.sender] >= _value);
balanceOf[_to] += _value;
balanceOf[_from] -= _value;
allowance[_from][msg.sender] -= _value;
Transfer(_from, _to, _value);
return true;
}
function approve(address _spender, uint256 _value)
public
validAddress(_spender)
returns (bool success)
{
require(_value == 0 || allowance[msg.sender][_spender] == 0);
allowance[msg.sender][_spender] = _value;
Approval(msg.sender, _spender, _value);
return true;
}
event Transfer(address indexed _from, address indexed _to, uint256 _value);
event Approval(address indexed _owner, address indexed _spender, uint256 _value);
}