Transaction Hash:
Block:
11885076 at Feb-19-2021 04:09:49 AM +UTC
Transaction Fee:
0.003112686 ETH
$6.31
Gas Used:
23,229 Gas / 134 Gwei
Emitted Events:
| 242 |
GateChainToken.Transfer( from=[Sender] 0x11acff60a9fa58f9d4e03c1e24d3e4b52b37d94d, to=0x6748F50f686bfbcA6Fe8ad62b22228b87F31ff2b, value=19995600000000000000000 )
|
Account State Difference:
| Address | Before | After | State Difference | ||
|---|---|---|---|---|---|
| 0x11ACfF60...52B37D94d |
0.054455268301626355 Eth
Nonce: 3969
|
0.051342582301626355 Eth
Nonce: 3970
| 0.003112686 | ||
|
0x829BD824...93333A830
Miner
| (F2Pool Old) | 1,232.738162734591166147 Eth | 1,232.741275420591166147 Eth | 0.003112686 | |
| 0xE66747a1...43b454759 |
Execution Trace
GateChainToken.transfer( to=0x6748F50f686bfbcA6Fe8ad62b22228b87F31ff2b, value=19995600000000000000000 ) => ( success=True )
pragma solidity ^0.5.0;
library SafeMath {
function add(uint256 a, uint256 b) internal pure returns (uint256 c) {
c = a + b;
require(c >= a);
}
function sub(uint256 a, uint256 b) internal pure returns (uint256 c) {
require(b <= a);
c = a - b;
}
function mul(uint256 a, uint256 b) internal pure returns (uint256 c) {
c = a * b;
require(a == 0 || c / a == b);
}
function div(uint256 a, uint256 b) internal pure returns (uint256 c) {
require(b > 0);
c = a / b;
}
}
contract ERC20Interface {
function totalSupply() public view returns (uint256);
function balanceOf(address tokenOwner) public view returns (uint256 balance);
function allowance(address tokenOwner, address spender) public view returns (uint256 remaining);
function transfer(address to, uint256 value) public returns (bool success);
function approve(address spender, uint256 value) public returns (bool success);
function transferFrom(address from, address to, uint256 value) public returns (bool success);
event Transfer(address indexed from, address indexed to, uint256 value);
event Approval(address indexed tokenOwner, address indexed spender, uint256 value);
}
contract GateChainToken is ERC20Interface {
using SafeMath for uint256;
string public symbol;
string public name;
uint8 public decimals;
uint256 _totalSupply;
address public owner;
bool public activeStatus = true;
event Active(address msgSender);
event Reset(address msgSender);
event Burn(address indexed from, uint256 value);
event Freeze(address indexed from, uint256 value);
event Unfreeze(address indexed from, uint256 value);
mapping(address => uint256) public balances;
mapping(address => uint256) public freezeOf;
mapping(address => mapping(address => uint256)) public allowed;
constructor() public {
symbol = "GT";
name = "GateChainToken";
decimals = 18;
_totalSupply = 300000000 * 10**uint(decimals);
owner = msg.sender;
balances[owner] = _totalSupply;
emit Transfer(address(0), owner, _totalSupply);
}
function isOwner(address add) public view returns (bool) {
if (add == owner) {
return true;
} else return false;
}
modifier onlyOwner {
if (!isOwner(msg.sender)) {
revert();
}
_;
}
modifier onlyActive {
if (!activeStatus) {
revert();
}
_;
}
function activeMode() public onlyOwner {
activeStatus = true;
emit Active(msg.sender);
}
function resetMode() public onlyOwner {
activeStatus = false;
emit Reset(msg.sender);
}
function totalSupply() public view returns (uint256) {
return _totalSupply;
}
function balanceOf(address tokenOwner) public view returns (uint256 balance) {
return balances[tokenOwner];
}
function allowance(address tokenOwner, address spender) public view returns (uint256 remaining) {
return allowed[tokenOwner][spender];
}
function transfer(address to, uint256 value) public onlyActive returns (bool success) {
if (to == address(0)) {
revert();
}
if (value <= 0) {
revert();
}
if (balances[msg.sender] < value) {
revert();
}
balances[msg.sender] = balances[msg.sender].sub(value);
balances[to] = balances[to].add(value);
emit Transfer(msg.sender, to, value);
return true;
}
function approve(address spender, uint256 value) public onlyActive returns (bool success) {
if (value <= 0) {
revert();
}
allowed[msg.sender][spender] = value;
emit Approval(msg.sender, spender, value);
return true;
}
function transferFrom(address from, address to, uint256 value) public onlyActive returns (bool success) {
if (to == address(0)) {
revert();
}
if (value <= 0) {
revert();
}
if (balances[from] < value) {
revert();
}
if (value > allowed[from][msg.sender]) {
revert();
}
balances[from] = balances[from].sub(value);
allowed[from][msg.sender] = allowed[from][msg.sender].sub(value);
balances[to] = balances[to].add(value);
emit Transfer(from, to, value);
return true;
}
function burn(uint256 value) public onlyActive returns (bool success) {
if (balances[msg.sender] < value) {
revert();
}
if (value <= 0) {
revert();
}
balances[msg.sender] = balances[msg.sender].sub(value);
_totalSupply = _totalSupply.sub(value);
emit Burn(msg.sender, value);
return true;
}
function freeze(uint256 value) public onlyActive returns (bool success) {
if (balances[msg.sender] < value) {
revert();
}
if (value <= 0){
revert();
}
balances[msg.sender] = balances[msg.sender].sub(value);
freezeOf[msg.sender] = freezeOf[msg.sender].add(value);
emit Freeze(msg.sender, value);
return true;
}
function unfreeze(uint256 value) public onlyActive returns (bool success) {
if (freezeOf[msg.sender] < value) {
revert();
}
if (value <= 0) {
revert();
}
freezeOf[msg.sender] = freezeOf[msg.sender].sub(value);
balances[msg.sender] = balances[msg.sender].add(value);
emit Unfreeze(msg.sender, value);
return true;
}
function () external payable {
revert();
}
}