ETH Price: $3,341.44 (+1.39%)
 
Transaction Hash
Method
Block
From
To
Transfer216875972025-01-23 13:50:112 days ago1737640211IN
0xA7c23c82...687536284
0.39967289 ETH0.00055620.3449348
Transfer216874892025-01-23 13:28:352 days ago1737638915IN
0xA7c23c82...687536284
0.41595988 ETH0.00048217.63694282
Transfer216874492025-01-23 13:20:112 days ago1737638411IN
0xA7c23c82...687536284
0.68528093 ETH0.0004504716.48328434
Transfer216742582025-01-21 17:08:234 days ago1737479303IN
0xA7c23c82...687536284
0.04543769 ETH0.000541619.81778196
Exec Transaction216735682025-01-21 14:49:594 days ago1737470999IN
0xA7c23c82...687536284
0 ETH0.00118819.18556678
Transfer216674472025-01-20 18:18:355 days ago1737397115IN
0xA7c23c82...687536284
0.09569362 ETH0.0009795435.84261792
Transfer216670462025-01-20 16:58:115 days ago1737392291IN
0xA7c23c82...687536284
0.29975532 ETH0.0010321137.76632679
Transfer216659542025-01-20 13:18:355 days ago1737379115IN
0xA7c23c82...687536284
0.08783961 ETH0.0007571727.70575928
Transfer216658272025-01-20 12:53:115 days ago1737377591IN
0xA7c23c82...687536284
2.53926945 ETH0.0007295226.69412262
Transfer216646222025-01-20 8:50:595 days ago1737363059IN
0xA7c23c82...687536284
0.11056807 ETH0.0008622831.55185988
Transfer216628302025-01-20 2:51:236 days ago1737341483IN
0xA7c23c82...687536284
0.29848335 ETH0.0009690635.45927952
Transfer216290092025-01-15 9:32:3510 days ago1736933555IN
0xA7c23c82...687536284
0.23487925 ETH0.000143565.25337662
Transfer216289402025-01-15 9:18:3510 days ago1736932715IN
0xA7c23c82...687536284
0.16920859 ETH0.000120744.4181325
Exec Transaction216020952025-01-11 15:20:2314 days ago1736608823IN
0xA7c23c82...687536284
0 ETH0.000241753.90415351
Transfer215809752025-01-08 16:33:1117 days ago1736353991IN
0xA7c23c82...687536284
0.35978584 ETH0.0003200611.71152657
Transfer215750902025-01-07 20:50:1118 days ago1736283011IN
0xA7c23c82...687536284
0.5160687 ETH0.0003497312.79737145
Transfer215743152025-01-07 18:14:2318 days ago1736273663IN
0xA7c23c82...687536284
2.99947943 ETH0.0003381812.37453443
Transfer215737422025-01-07 16:19:1118 days ago1736266751IN
0xA7c23c82...687536284
0.4351331 ETH0.0006780324.81010979
Transfer215735602025-01-07 15:42:3518 days ago1736264555IN
0xA7c23c82...687536284
0.05458983 ETH0.0007710128.21222825
Transfer215665272025-01-06 16:10:4719 days ago1736179847IN
0xA7c23c82...687536284
0.0998162 ETH0.0009129933.40761161
Transfer215661162025-01-06 14:48:1119 days ago1736174891IN
0xA7c23c82...687536284
0.33024446 ETH0.0004146615.172964
Transfer215660762025-01-06 14:40:1119 days ago1736174411IN
0xA7c23c82...687536284
0.0443153 ETH0.0003765413.77838441
Transfer215164662024-12-30 16:24:2326 days ago1735575863IN
0xA7c23c82...687536284
0.35543295 ETH0.000286510.48366294
Transfer215137552024-12-30 7:19:2326 days ago1735543163IN
0xA7c23c82...687536284
0.13884548 ETH0.00013084.7861719
Transfer215137362024-12-30 7:15:3526 days ago1735542935IN
0xA7c23c82...687536284
0.29955161 ETH0.000118764.34585095
View all transactions

Latest 4 internal transactions

Advanced mode:
Parent Transaction Hash Block
From
To
216735682025-01-21 14:49:594 days ago1737470999
0xA7c23c82...687536284
100 ETH
216020952025-01-11 15:20:2314 days ago1736608823
0xA7c23c82...687536284
35 ETH
214666982024-12-23 17:33:1133 days ago1734975191
0xA7c23c82...687536284
35 ETH
190673452024-01-23 5:38:11368 days ago1705988291  Contract Creation0 ETH
Loading...
Loading

Similar Match Source Code
This contract matches the deployed Bytecode of the Source Code for Contract 0xDaB5dc22...0ba42d2a6
The constructor portion of the code might be different and could alter the actual behaviour of the contract

Contract Name:
GnosisSafeProxy

Compiler Version
v0.7.6+commit.7338295f

Optimization Enabled:
No with 200 runs

Other Settings:
default evmVersion, GNU LGPLv3 license
/**
 *Submitted for verification at Etherscan.io on 2021-07-09
*/

// SPDX-License-Identifier: LGPL-3.0-only
pragma solidity >=0.7.0 <0.9.0;

/// @title IProxy - Helper interface to access masterCopy of the Proxy on-chain
/// @author Richard Meissner - <[email protected]>
interface IProxy {
    function masterCopy() external view returns (address);
}

/// @title GnosisSafeProxy - Generic proxy contract allows to execute all transactions applying the code of a master contract.
/// @author Stefan George - <[email protected]>
/// @author Richard Meissner - <[email protected]>
contract GnosisSafeProxy {
    // singleton 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 singleton;

    /// @dev Constructor function sets address of singleton contract.
    /// @param _singleton Singleton address.
    constructor(address _singleton) {
        require(_singleton != address(0), "Invalid singleton address provided");
        singleton = _singleton;
    }

    /// @dev Fallback function forwards all transactions and returns all received return data.
    fallback() external payable {
        // solhint-disable-next-line no-inline-assembly
        assembly {
            let _singleton := and(sload(0), 0xffffffffffffffffffffffffffffffffffffffff)
            // 0xa619486e == keccak("masterCopy()"). The value is right padded to 32-bytes with 0s
            if eq(calldataload(0), 0xa619486e00000000000000000000000000000000000000000000000000000000) {
                mstore(0, _singleton)
                return(0, 0x20)
            }
            calldatacopy(0, 0, calldatasize())
            let success := delegatecall(gas(), _singleton, 0, calldatasize(), 0, 0)
            returndatacopy(0, 0, returndatasize())
            if eq(success, 0) {
                revert(0, returndatasize())
            }
            return(0, returndatasize())
        }
    }
}

/// @title Proxy Factory - Allows to create new proxy contact and execute a message call to the new proxy within one transaction.
/// @author Stefan George - <[email protected]>
contract GnosisSafeProxyFactory {
    event ProxyCreation(GnosisSafeProxy proxy, address singleton);

    /// @dev Allows to create new proxy contact and execute a message call to the new proxy within one transaction.
    /// @param singleton Address of singleton contract.
    /// @param data Payload for message call sent to new proxy contract.
    function createProxy(address singleton, bytes memory data) public returns (GnosisSafeProxy proxy) {
        proxy = new GnosisSafeProxy(singleton);
        if (data.length > 0)
            // solhint-disable-next-line no-inline-assembly
            assembly {
                if eq(call(gas(), proxy, 0, add(data, 0x20), mload(data), 0, 0), 0) {
                    revert(0, 0)
                }
            }
        emit ProxyCreation(proxy, singleton);
    }

    /// @dev Allows to retrieve the runtime code of a deployed Proxy. This can be used to check that the expected Proxy was deployed.
    function proxyRuntimeCode() public pure returns (bytes memory) {
        return type(GnosisSafeProxy).runtimeCode;
    }

    /// @dev Allows to retrieve the creation code used for the Proxy deployment. With this it is easily possible to calculate predicted address.
    function proxyCreationCode() public pure returns (bytes memory) {
        return type(GnosisSafeProxy).creationCode;
    }

    /// @dev Allows to create new proxy contact using CREATE2 but it doesn't run the initializer.
    ///      This method is only meant as an utility to be called from other methods
    /// @param _singleton Address of singleton contract.
    /// @param initializer Payload for message call sent to new proxy contract.
    /// @param saltNonce Nonce that will be used to generate the salt to calculate the address of the new proxy contract.
    function deployProxyWithNonce(
        address _singleton,
        bytes memory initializer,
        uint256 saltNonce
    ) internal returns (GnosisSafeProxy proxy) {
        // If the initializer changes the proxy address should change too. Hashing the initializer data is cheaper than just concatinating it
        bytes32 salt = keccak256(abi.encodePacked(keccak256(initializer), saltNonce));
        bytes memory deploymentData = abi.encodePacked(type(GnosisSafeProxy).creationCode, uint256(uint160(_singleton)));
        // solhint-disable-next-line no-inline-assembly
        assembly {
            proxy := create2(0x0, add(0x20, deploymentData), mload(deploymentData), salt)
        }
        require(address(proxy) != address(0), "Create2 call failed");
    }

    /// @dev Allows to create new proxy contact and execute a message call to the new proxy within one transaction.
    /// @param _singleton Address of singleton contract.
    /// @param initializer Payload for message call sent to new proxy contract.
    /// @param saltNonce Nonce that will be used to generate the salt to calculate the address of the new proxy contract.
    function createProxyWithNonce(
        address _singleton,
        bytes memory initializer,
        uint256 saltNonce
    ) public returns (GnosisSafeProxy proxy) {
        proxy = deployProxyWithNonce(_singleton, initializer, saltNonce);
        if (initializer.length > 0)
            // solhint-disable-next-line no-inline-assembly
            assembly {
                if eq(call(gas(), proxy, 0, add(initializer, 0x20), mload(initializer), 0, 0), 0) {
                    revert(0, 0)
                }
            }
        emit ProxyCreation(proxy, _singleton);
    }

    /// @dev Allows to create new proxy contact, execute a message call to the new proxy and call a specified callback within one transaction
    /// @param _singleton Address of singleton contract.
    /// @param initializer Payload for message call sent to new proxy contract.
    /// @param saltNonce Nonce that will be used to generate the salt to calculate the address of the new proxy contract.
    /// @param callback Callback that will be invoced after the new proxy contract has been successfully deployed and initialized.
    function createProxyWithCallback(
        address _singleton,
        bytes memory initializer,
        uint256 saltNonce,
        IProxyCreationCallback callback
    ) public returns (GnosisSafeProxy proxy) {
        uint256 saltNonceWithCallback = uint256(keccak256(abi.encodePacked(saltNonce, callback)));
        proxy = createProxyWithNonce(_singleton, initializer, saltNonceWithCallback);
        if (address(callback) != address(0)) callback.proxyCreated(proxy, _singleton, initializer, saltNonce);
    }

    /// @dev Allows to get the address for a new proxy contact created via `createProxyWithNonce`
    ///      This method is only meant for address calculation purpose when you use an initializer that would revert,
    ///      therefore the response is returned with a revert. When calling this method set `from` to the address of the proxy factory.
    /// @param _singleton Address of singleton contract.
    /// @param initializer Payload for message call sent to new proxy contract.
    /// @param saltNonce Nonce that will be used to generate the salt to calculate the address of the new proxy contract.
    function calculateCreateProxyWithNonceAddress(
        address _singleton,
        bytes calldata initializer,
        uint256 saltNonce
    ) external returns (GnosisSafeProxy proxy) {
        proxy = deployProxyWithNonce(_singleton, initializer, saltNonce);
        revert(string(abi.encodePacked(proxy)));
    }
}

interface IProxyCreationCallback {
    function proxyCreated(
        GnosisSafeProxy proxy,
        address _singleton,
        bytes calldata initializer,
        uint256 saltNonce
    ) external;
}

Contract Security Audit

Contract ABI

[{"inputs":[{"internalType":"address","name":"_singleton","type":"address"}],"stateMutability":"nonpayable","type":"constructor"},{"stateMutability":"payable","type":"fallback"}]

Deployed Bytecode

0x608060405273ffffffffffffffffffffffffffffffffffffffff600054167fa619486e0000000000000000000000000000000000000000000000000000000060003514156050578060005260206000f35b3660008037600080366000845af43d6000803e60008114156070573d6000fd5b3d6000f3fea2646970667358221220d1429297349653a4918076d650332de1a1068c5f3e07c5c82360c277770b955264736f6c63430007060033

Deployed Bytecode Sourcemap

524:1528:0:-:0;;;1376:42;1372:1;1366:8;1362:57;1556:66;1552:1;1539:15;1536:87;1533:2;;;1653:10;1650:1;1643:21;1692:4;1689:1;1682:15;1533:2;1745:14;1742:1;1739;1726:34;1843:1;1840;1824:14;1821:1;1809:10;1802:5;1789:56;1880:16;1877:1;1874;1859:38;1926:1;1917:7;1914:14;1911:2;;;1958:16;1955:1;1948:27;1911:2;2014:16;2011:1;2004:27

Swarm Source

ipfs://d1429297349653a4918076d650332de1a1068c5f3e07c5c82360c277770b9552

Block Transaction Difficulty Gas Used Reward
View All Blocks Produced

Block Uncle Number Difficulty Gas Used Reward
View All Uncles
Loading...
Loading
Loading...
Loading

Validator Index Block Amount
View All Withdrawals

Transaction Hash Block Value Eth2 PubKey Valid
View All Deposits
Loading...
Loading
[ Download: CSV Export  ]
[ Download: CSV Export  ]

A contract address hosts a smart contract, which is a set of code stored on the blockchain that runs when predetermined conditions are met. Learn more about addresses in our Knowledge Base.