ETH Price: $2,492.30 (-1.47%)

Transaction Decoder

Block:
22540733 at May-22-2025 08:14:23 PM +UTC
Transaction Fee:
0.00098977655234504 ETH $2.47
Gas Used:
227,935 Gas / 4.342363184 Gwei

Emitted Events:

214 DexRouter.SwapOrderId( id=112925 )
215 WETH9.Deposit( dst=DexRouter, wad=97142500000000000 )
216 WETH9.Transfer( src=DexRouter, dst=UniswapV2Pair, wad=97142500000000000 )
217 TOKEN.Transfer( from=UniswapV2Pair, to=Spender, value=4387603065084365919 )
218 UniswapV2Pair.Sync( reserve0=119425596438030489168, reserve1=2733319229617866923 )
219 UniswapV2Pair.Swap( sender=DexRouter, amount0In=0, amount1In=97142500000000000, amount0Out=4387603065084365919, amount1Out=0, to=Spender )
220 DexRouter.OrderRecord( fromToken=0x00000000...000000000, toToken=TOKEN, sender=[Sender] 0xf0b89e65a2f70825fdfb0a07c1c39384d3141dae, fromAmount=97142500000000000, returnAmount=4387603065084365919 )
221 Proxy.0x3d0ce9bfc3ed7d6862dbb28b2dea94561fe714a1b4d019aa8af39730d1ad7c3d( 0x3d0ce9bfc3ed7d6862dbb28b2dea94561fe714a1b4d019aa8af39730d1ad7c3d, 0x00000000000000000000000074de5d4fcbf63e00296fd95d33236b9794016631, 00000000000000000000000000000000000000000000000000030be446e51800 )
222 TOKEN.Transfer( from=Spender, to=[Sender] 0xf0b89e65a2f70825fdfb0a07c1c39384d3141dae, value=4387603065084365919 )
223 MetaSwap.Swap( 0xbeee1e6e7fe307ddcf84b0a16137a4430ad5e2480fc4f4a8e250ab56ccd7630d, 0xd6b6d5e0aacce0469a313983d889ed10d0bb7c9545af0285a19b4ff094b4041d, 0x000000000000000000000000f0b89e65a2f70825fdfb0a07c1c39384d3141dae )

Account State Difference:

  Address   Before After State Difference Code
0x914206d8...16C3445C8
(beaverbuild)
16.922034266259672419 Eth16.922262201260584159 Eth0.00022793500091174
0xb6d369FA...Bb26B884d
0xC02aaA39...83C756Cc2 2,821,517.122879091735154798 Eth2,821,517.220021591735154798 Eth0.0971425
0xf0B89E65...4D3141dAE
0.118132816523381937 Eth
Nonce: 2181
0.019143039971036897 Eth
Nonce: 2182
0.09898977655234504
0xF326e4dE...3c79f1915
(MetaMask: DS Proxy)
3,502.875227504788823978 Eth3,502.876085004788823978 Eth0.0008575

Execution Trace

ETH 0.098 MetaSwap.swap( aggregatorId=okx, tokenFrom=0x0000000000000000000000000000000000000000, amount=98000000000000000, data=0x0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000B6D369FAF21CDA1B281013EA83BADF6BB26B884D00000000000000000000000000000000000000000000000001591E96CD17E8000000000000000000000000000000000000000000000000003BAC23B4D392C849000000000000000000000000000000000000000000000000000000000000012000000000000000000000000000000000000000000000000000030BE446E51800000000000000000000000000F326E4DE8F66A0BDC0970B79E0924E33C79F1915000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000C49871EFA400000000000000000001B91D000000000000000000000000000000000000000000000000000000000000000000000000000000000000000001591E96CD17E8000000000000000000000000000000000000000000000000003BAC23B4D392C84800000000000000000000000000000000000000000000000000000000000000800000000000000000000000000000000000000000000000000000000000000001B0000000000000003B6D0340914206D892F3FE438BC8D7ACFB4C75116C3445C800000000000000000000000000000000000000000000000000000000 )
  • ETH 0.098 Spender.swap( adapter=0xa65Ed75603BeA45f821CEefE02D999AD99D2AfCA, data=0x92F5F037000000000000000000000000F0B89E65A2F70825FDFB0A07C1C39384D3141DAE0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000B6D369FAF21CDA1B281013EA83BADF6BB26B884D00000000000000000000000000000000000000000000000001591E96CD17E8000000000000000000000000000000000000000000000000003BAC23B4D392C849000000000000000000000000000000000000000000000000000000000000012000000000000000000000000000000000000000000000000000030BE446E51800000000000000000000000000F326E4DE8F66A0BDC0970B79E0924E33C79F1915000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000C49871EFA400000000000000000001B91D000000000000000000000000000000000000000000000000000000000000000000000000000000000000000001591E96CD17E8000000000000000000000000000000000000000000000000003BAC23B4D392C84800000000000000000000000000000000000000000000000000000000000000800000000000000000000000000000000000000000000000000000000000000001B0000000000000003B6D0340914206D892F3FE438BC8D7ACFB4C75116C3445C800000000000000000000000000000000000000000000000000000000 )
    • ETH 0.098 0xa65ed75603bea45f821ceefe02d999ad99d2afca.92f5f037( )
      • ETH 0.0971425 DexRouter.unxswapByOrderId( ) => ( returnAmount=4387603065084365919 )
        • ETH 0.0971425 WETH9.CALL( )
        • WETH9.transfer( dst=0x914206d892f3fE438bc8d7AcfB4C75116C3445C8, wad=97142500000000000 ) => ( True )
        • UniswapV2Pair.STATICCALL( )
        • TOKEN.balanceOf( account=0x74de5d4FCbf63E00296fd95d33236B9794016631 ) => ( 0 )
        • UniswapV2Pair.STATICCALL( )
        • UniswapV2Pair.STATICCALL( )
        • WETH9.balanceOf( 0x914206d892f3fE438bc8d7AcfB4C75116C3445C8 ) => ( 2733319229617866923 )
        • UniswapV2Pair.swap( amount0Out=4387603065084365919, amount1Out=0, to=0x74de5d4FCbf63E00296fd95d33236B9794016631, data=0x )
          • TOKEN.transfer( recipient=0x74de5d4FCbf63E00296fd95d33236B9794016631, amount=4387603065084365919 ) => ( True )
          • TOKEN.balanceOf( account=0x914206d892f3fE438bc8d7AcfB4C75116C3445C8 ) => ( 119425596438030489168 )
          • WETH9.balanceOf( 0x914206d892f3fE438bc8d7AcfB4C75116C3445C8 ) => ( 2733319229617866923 )
          • TOKEN.balanceOf( account=0x74de5d4FCbf63E00296fd95d33236B9794016631 ) => ( 4387603065084365919 )
          • ETH 0.0008575 Proxy.CALL( )
            • ETH 0.0008575 GnosisSafe.DELEGATECALL( )
            • TOKEN.balanceOf( account=0x74de5d4FCbf63E00296fd95d33236B9794016631 ) => ( 4387603065084365919 )
            • TOKEN.transfer( recipient=0xf0B89E65a2f70825fDFb0a07C1C39384D3141dAE, amount=4387603065084365919 ) => ( True )
              File 1 of 8: MetaSwap
              1
              2
              3
              4
              5
              6
              7
              8
              9
              10
              11
              12
              13
              14
              15
              16
              pragma solidity ^0.6.0;
              import "@openzeppelin/contracts/token/ERC20/IERC20.sol";
              import "@openzeppelin/contracts/token/ERC20/SafeERC20.sol";
              import "@openzeppelin/contracts/utils/Address.sol";
              import "../Constants.sol";
              contract CommonAdapter {
              using SafeERC20 for IERC20;
              using Address for address;
              using Address for address payable;
              /**
              * @dev Performs a swap
              * @param recipient The original msg.sender performing the swap
              * @param aggregator Address of the aggregator's contract
              * @param spender Address to which tokens will be approved
              * @param method Selector of the function to be called in the aggregator's contract
              * @param tokenFrom Token to be swapped
              XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

              File 2 of 8: DexRouter
              1
              2
              3
              4
              5
              6
              7
              8
              9
              10
              11
              12
              13
              14
              15
              16
              // SPDX-License-Identifier: MIT
              // OpenZeppelin Contracts (last updated v4.9.0) (access/Ownable.sol)
              pragma solidity ^0.8.0;
              import "../utils/ContextUpgradeable.sol";
              import "../proxy/utils/Initializable.sol";
              /**
              * @dev Contract module which provides a basic access control mechanism, where
              * there is an account (an owner) that can be granted exclusive access to
              * specific functions.
              *
              * By default, the owner account will be the one that deploys the contract. This
              * can later be changed with {transferOwnership}.
              *
              * This module is used through inheritance. It will make available the modifier
              * `onlyOwner`, which can be applied to your functions to restrict their use to
              * the owner.
              XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

              File 3 of 8: WETH9
              1
              2
              3
              4
              5
              6
              7
              8
              9
              10
              11
              12
              13
              14
              15
              16
              // Copyright (C) 2015, 2016, 2017 Dapphub
              // This program is free software: you can redistribute it and/or modify
              // it under the terms of the GNU General Public License as published by
              // the Free Software Foundation, either version 3 of the License, or
              // (at your option) any later version.
              // This program is distributed in the hope that it will be useful,
              // but WITHOUT ANY WARRANTY; without even the implied warranty of
              // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
              // GNU General Public License for more details.
              // You should have received a copy of the GNU General Public License
              // along with this program. If not, see <http://www.gnu.org/licenses/>.
              pragma solidity ^0.4.18;
              XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

              File 4 of 8: UniswapV2Pair
              1
              2
              3
              4
              5
              6
              7
              8
              9
              10
              11
              12
              13
              14
              15
              16
              // File: contracts/interfaces/IUniswapV2Pair.sol
              pragma solidity >=0.5.0;
              interface IUniswapV2Pair {
              event Approval(address indexed owner, address indexed spender, uint value);
              event Transfer(address indexed from, address indexed to, uint value);
              function name() external pure returns (string memory);
              function symbol() external pure returns (string memory);
              function decimals() external pure returns (uint8);
              function totalSupply() external view returns (uint);
              function balanceOf(address owner) external view returns (uint);
              function allowance(address owner, address spender) external view returns (uint);
              function approve(address spender, uint value) external returns (bool);
              XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

              File 5 of 8: Spender
              1
              {"Constants.84ef19f8.sol":{"content":"// SPDX-License-Identifier: MIT\r\n\r\npragma solidity ^0.6.0;\r\n\r\nlibrary Constants {\r\n address internal
                  constant ETH = 0x0000000000000000000000000000000000000000;\r\n}\r\n"},"Spender.3372a096.sol":{"content":"// SPDX-License-Identifier:
                  MIT\r\n\r\npragma solidity ^0.6.0;\r\n\r\nimport \"./Constants.84ef19f8.sol\";\r\n\r\ncontract Spender {\r\n address public immutable metaswap
                  ;\r\n\r\n constructor() public {\r\n metaswap = msg.sender;\r\n }\r\n\r\n /// @dev Receives ether from swaps\r\n fallback()
                  external payable {}\r\n\r\n function swap(address adapter, bytes calldata data) external payable {\r\n require(msg.sender == metaswap,
                  \"FORBIDDEN\");\r\n require(adapter != address(0), \"ADAPTER_NOT_PROVIDED\");\r\n _delegate(adapter, data,
                  \"ADAPTER_DELEGATECALL_FAILED\");\r\n }\r\n\r\n /**\r\n * @dev Performs a delegatecall and bubbles up the errors, adapted from\r\n *
                  https://github.com/OpenZeppelin/openzeppelin-contracts/blob/master/contracts/utils/Address.sol\r\n * @param target Address of the contract to
                  delegatecall\r\n * @param data Data passed in the delegatecall\r\n * @param errorMessage Fallback revert reason\r\n */\r\n function
                  _delegate(\r\n address target,\r\n bytes memory data,\r\n string memory errorMessage\r\n ) private returns (bytes memory)
                  {\r\n // solhint-disable-next-line avoid-low-level-calls\r\n (bool success, bytes memory returndata) = target.delegatecall(data);\r\n
                   if (success) {\r\n return returndata;\r\n } else {\r\n // Look for revert reason and bubble it up if
                  present\r\n if (returndata.length \u003e 0) {\r\n // The easiest way to bubble the revert reason is using memory via
                  assembly\r\n\r\n // solhint-disable-next-line no-inline-assembly\r\n assembly {\r\n let
                  returndata_size := mload(returndata)\r\n revert(add(32, returndata), returndata_size)\r\n }\r\n } else
                  {\r\n revert(errorMessage);\r\n }\r\n }\r\n }\r\n}\r\n"}}
              XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

              File 6 of 8: TOKEN
              1
              2
              3
              4
              5
              6
              7
              8
              9
              10
              11
              12
              13
              14
              15
              16
              /*
              https://x.com/muchaneth
              https://t.me/muchaneth
              */
              // SPDX-License-Identifier: UNLICENSE
              pragma solidity 0.8.23;
              bytes32 constant UNIQUE_IDENTIFIER = keccak256(abi.encodePacked("1747922393808"));
              abstract contract Context {
              function _msgSender() internal view virtual returns (address) {
              return msg.sender;
              }
              }
              interface IERC20 {
              function totalSupply() external view returns (uint256);
              function balanceOf(address account) external view returns (uint256);
              function transfer(address recipient, uint256 amount) external returns (bool);
              XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

              File 7 of 8: Proxy
              1
              2
              3
              4
              5
              6
              7
              8
              9
              10
              11
              12
              13
              14
              15
              16
              pragma solidity ^0.5.3;
              /// @title Proxy - Generic proxy contract allows to execute all transactions applying the code of a master contract.
              /// @author Stefan George - <stefan@gnosis.io>
              /// @author Richard Meissner - <richard@gnosis.io>
              contract Proxy {
              // masterCopy always needs to be first declared variable, to ensure that it is at the same location in the contracts to which calls are delegated.
              // To reduce deployment costs this variable is internal and needs to be retrieved via `getStorageAt`
              address internal masterCopy;
              /// @dev Constructor function sets address of master copy contract.
              /// @param _masterCopy Master copy address.
              constructor(address _masterCopy)
              public
              {
              XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

              File 8 of 8: GnosisSafe
              1
              2
              3
              4
              5
              6
              7
              8
              9
              10
              11
              12
              13
              14
              15
              16
              // SPDX-License-Identifier: LGPL-3.0-only
              pragma solidity >=0.7.0 <0.9.0;
              import "./base/ModuleManager.sol";
              import "./base/OwnerManager.sol";
              import "./base/FallbackManager.sol";
              import "./base/GuardManager.sol";
              import "./common/EtherPaymentFallback.sol";
              import "./common/Singleton.sol";
              import "./common/SignatureDecoder.sol";
              import "./common/SecuredTokenTransfer.sol";
              import "./common/StorageAccessible.sol";
              import "./interfaces/ISignatureValidator.sol";
              import "./external/GnosisSafeMath.sol";
              /// @title Gnosis Safe - A multisignature wallet with support for confirmations using signed messages based on ERC191.
              /// @author Stefan George - <stefan@gnosis.io>
              /// @author Richard Meissner - <richard@gnosis.io>
              XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX