ETH Price: $2,637.51 (+0.82%)

Transaction Decoder

Block:
22544158 at May-23-2025 07:44:35 AM +UTC
Transaction Fee:
0.000488211443282112 ETH $1.29
Gas Used:
189,444 Gas / 2.577075248 Gwei

Emitted Events:

61 TetherToken.Transfer( from=[Sender] 0x3c8437e1a15dfb9188ad913a066921f7e36c935d, to=Spender, value=14721254 )
62 TetherToken.Transfer( from=Spender, to=0x51C72848c68a965f66FA7a88855F9f7784502a7F, value=14721254 )
63 WETH9.Transfer( src=0x51C72848c68a965f66FA7a88855F9f7784502a7F, dst=Spender, wad=5530279141083055 )
64 WETH9.Transfer( src=0x51C72848c68a965f66FA7a88855F9f7784502a7F, dst=SplitWallet, wad=2765139570541 )
65 SwapERC20.SwapERC20( nonce=1747239887443, signerWallet=0x51C72848c68a965f66FA7a88855F9f7784502a7F )
66 WETH9.Withdrawal( src=Spender, wad=48389942484477 )
67 Proxy.0x3d0ce9bfc3ed7d6862dbb28b2dea94561fe714a1b4d019aa8af39730d1ad7c3d( 0x3d0ce9bfc3ed7d6862dbb28b2dea94561fe714a1b4d019aa8af39730d1ad7c3d, 0x00000000000000000000000074de5d4fcbf63e00296fd95d33236b9794016631, 00000000000000000000000000000000000000000000000000002c02a9551dfd )
68 WETH9.Withdrawal( src=Spender, wad=5481889198598578 )
69 MetaSwap.Swap( 0xbeee1e6e7fe307ddcf84b0a16137a4430ad5e2480fc4f4a8e250ab56ccd7630d, 0x74008a9e83921090a0cc3c37a7b39398a692db963164a76e069ab2e8fb053e10, 0x0000000000000000000000003c8437e1a15dfb9188ad913a066921f7e36c935d )

Account State Difference:

  Address   Before After State Difference Code
0x3C8437e1...7E36C935D
0.006385338386982806 Eth
Nonce: 25
0.011379016142299272 Eth
Nonce: 26
0.004993677755316466
0xC02aaA39...83C756Cc2 2,790,389.580639836625731024 Eth2,790,389.575109557484647969 Eth0.005530279141083055
0xD82E10B9...e6CF2fC46
(AirSwap: V5 DEX SwapERC20)
0xdAC17F95...13D831ec7
(BuilderNet)
13.312271137588338098 Eth13.312460581589095874 Eth0.000189444000757776
0xF326e4dE...3c79f1915
(MetaMask: DS Proxy)
3,509.671517878640618041 Eth3,509.671566268583102518 Eth0.000048389942484477

Execution Trace

MetaSwap.swap( aggregatorId=airSwap4_3FeeDynamic, tokenFrom=0xdAC17F958D2ee523a2206206994597C13D831ec7, amount=14721254, data=0x00000000000000000000000000000000000000000000000000000196CF9CE25300000000000000000000000000000000000000000000000000000000683027D100000000000000000000000051C72848C68A965F66FA7A88855F9F7784502A7F00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000013A5C273B687AF000000000000000000000000DAC17F958D2EE523A2206206994597C13D831EC70000000000000000000000000000000000000000000000000000000000E0A0E6000000000000000000000000000000000000000000000000000000000000001C10FABB1D00CB9AE18077668E18513567E7A1688B1D3581125FCDB92D3F97699C12E433983A7017A7C8C1D4578F5886317DDE60E9E62649970FFAF0C4557755DA00000000000000000000000000000000000000000000000000002C02A9551DFD000000000000000000000000F326E4DE8F66A0BDC0970B79E0924E33C79F19150000000000000000000000000000000000000000000000000000000000000001 )
  • TetherToken.transferFrom( _from=0x3C8437e1A15DFb9188AD913a066921f7E36C935D, _to=0x74de5d4FCbf63E00296fd95d33236B9794016631, _value=14721254 )
  • Spender.swap( adapter=0x60FBaF99832Fb4360351AbC2b55e4B1F2fe98c71, data=0x4495C0880000000000000000000000003C8437E1A15DFB9188AD913A066921F7E36C935D00000000000000000000000000000000000000000000000000000196CF9CE25300000000000000000000000000000000000000000000000000000000683027D100000000000000000000000051C72848C68A965F66FA7A88855F9F7784502A7F00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000013A5C273B687AF000000000000000000000000DAC17F958D2EE523A2206206994597C13D831EC70000000000000000000000000000000000000000000000000000000000E0A0E6000000000000000000000000000000000000000000000000000000000000001C10FABB1D00CB9AE18077668E18513567E7A1688B1D3581125FCDB92D3F97699C12E433983A7017A7C8C1D4578F5886317DDE60E9E62649970FFAF0C4557755DA00000000000000000000000000000000000000000000000000002C02A9551DFD000000000000000000000000F326E4DE8F66A0BDC0970B79E0924E33C79F19150000000000000000000000000000000000000000000000000000000000000001 )
    • 0x60fbaf99832fb4360351abc2b55e4b1f2fe98c71.4495c088( )
      • TetherToken.allowance( _owner=0x74de5d4FCbf63E00296fd95d33236B9794016631, _spender=0xD82E10B9A4107939e55fCCa9B53A9ede6CF2fC46 ) => ( remaining=115792089237316195423570985008687907853269984665640564039457584007913129639935 )
      • SwapERC20.swapLight( nonce=1747239887443, expiry=1747986385, signerWallet=0x51C72848c68a965f66FA7a88855F9f7784502a7F, signerToken=0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2, signerAmount=5530279141083055, senderToken=0xdAC17F958D2ee523a2206206994597C13D831ec7, senderAmount=14721254, v=28, r=10FABB1D00CB9AE18077668E18513567E7A1688B1D3581125FCDB92D3F97699C, s=12E433983A7017A7C8C1D4578F5886317DDE60E9E62649970FFAF0C4557755DA )
        • Null: 0x000...001.da7b0a39( )
        • TetherToken.transferFrom( _from=0x74de5d4FCbf63E00296fd95d33236B9794016631, _to=0x51C72848c68a965f66FA7a88855F9f7784502a7F, _value=14721254 )
        • WETH9.transferFrom( src=0x51C72848c68a965f66FA7a88855F9f7784502a7F, dst=0x74de5d4FCbf63E00296fd95d33236B9794016631, wad=5530279141083055 ) => ( True )
        • WETH9.transferFrom( src=0x51C72848c68a965f66FA7a88855F9f7784502a7F, dst=0xaD30f7EEBD9Bd5150a256F47DA41d4403033CdF0, wad=2765139570541 ) => ( True )
        • WETH9.withdraw( wad=48389942484477 )
          • ETH 0.000048389942484477 Spender.CALL( )
          • ETH 0.000048389942484477 Proxy.CALL( )
            • ETH 0.000048389942484477 GnosisSafe.DELEGATECALL( )
            • TetherToken.balanceOf( who=0x74de5d4FCbf63E00296fd95d33236B9794016631 ) => ( 0 )
            • WETH9.balanceOf( 0x74de5d4FCbf63E00296fd95d33236B9794016631 ) => ( 5481889198598578 )
            • WETH9.withdraw( wad=5481889198598578 )
              • ETH 0.005481889198598578 Spender.CALL( )
              • ETH 0.005481889198598578 0x3c8437e1a15dfb9188ad913a066921f7e36c935d.CALL( )
                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: 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 3 of 8: TetherToken
                1
                2
                3
                4
                5
                6
                7
                8
                9
                10
                11
                12
                13
                14
                15
                16
                pragma solidity ^0.4.17;
                /**
                * @title SafeMath
                * @dev Math operations with safety checks that throw on error
                */
                library SafeMath {
                function mul(uint256 a, uint256 b) internal pure returns (uint256) {
                if (a == 0) {
                return 0;
                }
                uint256 c = a * b;
                assert(c / a == b);
                return c;
                }
                XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

                File 4 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 5 of 8: SplitWallet
                1
                2
                3
                4
                5
                6
                7
                8
                9
                10
                11
                12
                13
                14
                15
                16
                // SPDX-License-Identifier: GPL-3.0-or-later
                pragma solidity 0.8.4;
                import {ISplitMain} from './interfaces/ISplitMain.sol';
                import {ERC20} from '@rari-capital/solmate/src/tokens/ERC20.sol';
                import {SafeTransferLib} from '@rari-capital/solmate/src/utils/SafeTransferLib.sol';
                /**
                * ERRORS
                */
                /// @notice Unauthorized sender
                error Unauthorized();
                /**
                * @title SplitWallet
                * @author 0xSplits <will@0xSplits.xyz>
                * @notice The implementation logic for `SplitProxy`.
                * @dev `SplitProxy` handles `receive()` itself to avoid the gas cost with `DELEGATECALL`.
                */
                XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

                File 6 of 8: SwapERC20
                1
                2
                3
                4
                5
                6
                7
                8
                9
                10
                11
                12
                13
                14
                15
                16
                // SPDX-License-Identifier: MIT
                pragma solidity 0.8.23;
                interface ISwapERC20 {
                struct OrderERC20 {
                uint256 nonce; // Unique number per signatory per order
                uint256 expiry; // Expiry time (seconds since unix epoch)
                address signerWallet; // Party to the swap that sets terms
                address signerToken; // ERC20 token address transferred from signer
                uint256 signerAmount; // Amount of tokens transferred from signer
                address senderWallet; // Party to the swap that accepts terms
                address senderToken; // ERC20 token address transferred from sender
                uint256 senderAmount; // Amount of tokens transferred from sender
                uint8 v; // ECDSA
                bytes32 r;
                bytes32 s;
                }
                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