ETH Price: $3,477.30 (+3.09%)
Gas: 3.04 Gwei

Transaction Decoder

Block:
20487388 at Aug-09-2024 12:14:23 AM +UTC
Transaction Fee:
0.000663825690208806 ETH $2.31
Gas Used:
175,426 Gas / 3.784078131 Gwei

Emitted Events:

220 ZigCoin.Transfer( from=[Sender] 0x82c5c6d83041e34b186582bf10128d66ba93003f, to=Spender, value=3911239365588693443014 )
221 ZigCoin.Approval( owner=[Sender] 0x82c5c6d83041e34b186582bf10128d66ba93003f, spender=[Receiver] MetaSwap, value=115792089237316195423570985008687907853269984665640564035546344642324436196921 )
222 ZigCoin.Transfer( from=Spender, to=UniswapV2Pair, value=3911239365588693443014 )
223 ZigCoin.Approval( owner=Spender, spender=AggregationRouterV5, value=115792089237316195423570985008687907853269984665640520205016177328958420038314 )
224 WETH9.Transfer( src=UniswapV2Pair, dst=AggregationRouterV5, wad=170431809378276765 )
225 UniswapV2Pair.Sync( reserve0=6695670311311346639469842, reserve1=292470048681362926158 )
226 UniswapV2Pair.Swap( sender=AggregationRouterV5, amount0In=3911239365588693443014, amount1In=0, amount0Out=0, amount1Out=170431809378276765, to=AggregationRouterV5 )
227 WETH9.Withdrawal( src=AggregationRouterV5, wad=170431809378276765 )
228 Proxy.0x3d0ce9bfc3ed7d6862dbb28b2dea94561fe714a1b4d019aa8af39730d1ad7c3d( 0x3d0ce9bfc3ed7d6862dbb28b2dea94561fe714a1b4d019aa8af39730d1ad7c3d, 0x00000000000000000000000074de5d4fcbf63e00296fd95d33236b9794016631, 0000000000000000000000000000000000000000000000000005528a08ac176b )
229 MetaSwap.Swap( 0xbeee1e6e7fe307ddcf84b0a16137a4430ad5e2480fc4f4a8e250ab56ccd7630d, 0xf35f348d53012d52a5d39f9390d246956ac932d5778d2bb49e359dba4fa0896d, 0x00000000000000000000000082c5c6d83041e34b186582bf10128d66ba93003f )

Account State Difference:

  Address   Before After State Difference Code
0x82c5C6D8...6ba93003F
0.016851582172341292 Eth
Nonce: 91
0.185121438172395576 Eth
Nonce: 92
0.168269856000054284
(beaverbuild)
7.841437502550962867 Eth7.841717479600676017 Eth0.00027997704971315
0xb2617246...99ca94f01
0xb36ec83D...96Bb65460
0xC02aaA39...83C756Cc2 2,835,747.864617080246134969 Eth2,835,747.694185270867858204 Eth0.170431809378276765
0xF326e4dE...3c79f1915
(MetaMask: DS Proxy)
5,175.796785200651648504 Eth5,175.798283328339662179 Eth0.001498127688013675

Execution Trace

MetaSwap.swap( aggregatorId=oneInchV5FeeDynamic, tokenFrom=0xb2617246d0c6c0087f18703d576831899ca94f01, amount=3911239365588693443014, data=0x000000000000000000000000B2617246D0C6C0087F18703D576831899CA94F0100000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000D40759985E5E4261C6000000000000000000000000000000000000000000000000024EE519F5FDC16300000000000000000000000000000000000000000000000000000000000001200000000000000000000000000000000000000000000000000005528A08AC176B000000000000000000000000F326E4DE8F66A0BDC0970B79E0924E33C79F1915000000000000000000000000000000000000000000000000000000000000000100000000000000000000000000000000000000000000000000000000000000C80502B1C5000000000000000000000000B2617246D0C6C0087F18703D576831899CA94F010000000000000000000000000000000000000000000000D40759985E5E4261C600000000000000000000000000000000000000000000000002541C63CB4A3EBC0000000000000000000000000000000000000000000000000000000000000080000000000000000000000000000000000000000000000000000000000000000140000000000000003B6D0340B36EC83D844C0579EC2493F10B2087E96BB654607DCBEA7C000000000000000000000000000000000000000000000000 )
  • ZigCoin.transferFrom( sender=0x82c5C6D83041e34B186582bF10128D66ba93003F, recipient=0x74de5d4FCbf63E00296fd95d33236B9794016631, amount=3911239365588693443014 ) => ( True )
  • Spender.swap( adapter=0x7CDf68CE9A05413Cbb76cb7F80EAF415A826E313, data=0x92F5F03700000000000000000000000082C5C6D83041E34B186582BF10128D66BA93003F000000000000000000000000B2617246D0C6C0087F18703D576831899CA94F0100000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000D40759985E5E4261C6000000000000000000000000000000000000000000000000024EE519F5FDC16300000000000000000000000000000000000000000000000000000000000001200000000000000000000000000000000000000000000000000005528A08AC176B000000000000000000000000F326E4DE8F66A0BDC0970B79E0924E33C79F1915000000000000000000000000000000000000000000000000000000000000000100000000000000000000000000000000000000000000000000000000000000C80502B1C5000000000000000000000000B2617246D0C6C0087F18703D576831899CA94F010000000000000000000000000000000000000000000000D40759985E5E4261C600000000000000000000000000000000000000000000000002541C63CB4A3EBC0000000000000000000000000000000000000000000000000000000000000080000000000000000000000000000000000000000000000000000000000000000140000000000000003B6D0340B36EC83D844C0579EC2493F10B2087E96BB654607DCBEA7C000000000000000000000000000000000000000000000000 )
    • 0x7cdf68ce9a05413cbb76cb7f80eaf415a826e313.92f5f037( )
      • ZigCoin.allowance( owner=0x74de5d4FCbf63E00296fd95d33236B9794016631, spender=0x1111111254EEB25477B68fb85Ed929f73A960582 ) => ( 115792089237316195423570985008687907853269984665640520208927416694547113481328 )
      • AggregationRouterV5.unoswap( srcToken=0xb2617246d0c6c0087f18703d576831899ca94f01, amount=3911239365588693443014, minReturn=167790301057531580, pools=[28948022309329048857349863385615267046106139143314748366532033619485909210208] ) => ( returnAmount=170431809378276765 )
        • ZigCoin.transferFrom( sender=0x74de5d4FCbf63E00296fd95d33236B9794016631, recipient=0xb36ec83D844c0579Ec2493f10b2087E96Bb65460, amount=3911239365588693443014 ) => ( True )
        • UniswapV2Pair.STATICCALL( )
        • UniswapV2Pair.swap( amount0Out=0, amount1Out=170431809378276765, to=0x1111111254EEB25477B68fb85Ed929f73A960582, data=0x )
          • WETH9.transfer( dst=0x1111111254EEB25477B68fb85Ed929f73A960582, wad=170431809378276765 ) => ( True )
          • ZigCoin.balanceOf( account=0xb36ec83D844c0579Ec2493f10b2087E96Bb65460 ) => ( 6695670311311346639469842 )
          • WETH9.balanceOf( 0xb36ec83D844c0579Ec2493f10b2087E96Bb65460 ) => ( 292470048681362926158 )
          • WETH9.withdraw( wad=170431809378276765 )
            • ETH 0.170431809378276765 AggregationRouterV5.CALL( )
            • ETH 0.170431809378276765 Spender.CALL( )
            • ETH 0.001498127688013675 Proxy.CALL( )
              • ETH 0.001498127688013675 GnosisSafe.DELEGATECALL( )
              • ZigCoin.balanceOf( account=0x74de5d4FCbf63E00296fd95d33236B9794016631 ) => ( 0 )
              • ETH 0.16893368169026309 0x82c5c6d83041e34b186582bf10128d66ba93003f.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: ZigCoin
                1
                2
                3
                4
                5
                6
                7
                8
                9
                10
                11
                12
                13
                14
                15
                16
                // SPDX-License-Identifier: MIT
                pragma solidity ^0.7.6;
                import './ERC20.sol';
                contract ZigCoin is ERC20 {
                constructor() ERC20("ZigCoin", "ZIG") {
                // Fix supply: 2.000.000.000 tokens
                _mint(msg.sender, 2000000000 * 10 ** 18);
                }
                }
                // SPDX-License-Identifier: MIT
                pragma solidity ^0.7.6;
                import "../interfaces/IERC20.sol";
                import "../libraries/SafeMath.sol";
                /**
                * @dev Implementation of the {IERC20} interface.
                *
                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: AggregationRouterV5
                1
                2
                3
                4
                5
                6
                7
                8
                9
                10
                11
                12
                13
                14
                15
                16
                /*
                ,▄▓▓██▌ ,╓▄▄▓▓▓▓▓▓▓▓▄▄▄,,
                ,▓██▓███▓▄▓███▓╬╬╬╬╬╬╬╬╬╬╬╬╬▓███▓▄,
                ▄█ ▓██╬╣███████╬▓▀╬╬▓▓▓████████████▓█████▄,
                ▓██▌ ▓██╬╣██████╬▓▌ ██████████████████████▌╙╙▀ⁿ
                ▐████████╬▓████▓▓█╨ ▄ ╟█████████▓▓╬╬╬╬╬▓▓█████▓▄
                └▀▓▓▄╓ ╟█▓╣█████▓██████▀ ╓█▌ ███████▓▓▓▓▓╬╬╬╬╬╬╬╬╬╬╬╬▓██▓▄
                └▀████▓▄╥ ▐██╬╬██████████╙ Æ▀─ ▓███▀╚╠╬╩▀▀███████▓▓╬╬╬╬╬╬╬╬╬██▄
                └▀██▓▀▀█████▓╬▓██████▀ ▄█████▒╠" └╙▓██████▓╬╬╬╬╬╬╬╬██▄
                └▀██▄,└╙▀▀████▌└╙ ^"▀╙╙╙"╙██ @▄ ╙▀███████╬╬╬╬╬╬╬██µ
                └▀██▓▄, ██▌ ╒ ╙█▓ ]▓█▓╔ ▀███████▓╬╬╬╬╬▓█▌
                ▀█████ ▓ ╟█▌ ]╠██▓░▒╓ ▀████████╬╬╬╬╣█▌
                ▐████ ╓█▀█▌ ,██▌ ╚Å███▓▒▒╠╓ ╙█████████╬╬╬╣█▌
                └████ ▓█░░▓█ ▀▀▀ φ▒╫████▒▒▒▒╠╓ █████████▓╬╬▓█µ
                ╘███µ ▌▄█▓▄▓▀` ,▀ ,╔╠░▓██████▌╠▒▒▒φ ██████████╬╬██
                ▐████µ╙▓▀` ,▀╙,╔╔φφφ╠░▄▓███████▌░▓╙▒▒▒╠ └██╬███████╬▓█⌐
                XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

                File 6 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 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