Transaction Hash:
Block:
21623932 at Jan-14-2025 04:29:59 PM +UTC
Transaction Fee:
0.00045176717920086 ETH
$1.12
Gas Used:
48,420 Gas / 9.330177183 Gwei
Emitted Events:
407 |
TROY.Approval( tokenOwner=[Sender] 0x5f939de0e81a199a34e50615f34cbab82412459a, spender=0x7a250d56...659F2488D, value=392013076930000000000000000 )
|
Account State Difference:
Address | Before | After | State Difference | ||
---|---|---|---|---|---|
0x4574562E...a06875b1A | |||||
0x4838B106...B0BAD5f97
Miner
| (Titan Builder) | 13.79226524025153262 Eth | 13.79227008225153262 Eth | 0.000004842 | |
0x5F939de0...82412459a |
8.042597065604844618 Eth
Nonce: 93
|
8.042145298425643758 Eth
Nonce: 94
| 0.00045176717920086 |
Execution Trace
TROY.approve( spender=0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D, value=392013076930000000000000000 ) => ( success=True )
approve[TROY (ln:124)]
revert[TROY (ln:126)]
Approval[TROY (ln:129)]
/** *Submitted for verification at Etherscan.io on 2019-11-28 */ 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 TROY 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 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 = "TROY"; name = "TROY"; decimals = 18; _totalSupply = 10000000000 * 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 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(); } }