ETH Price: $3,364.03 (+1.18%)

Contract

0xc1caF495A1bBA5bf645bB32283CBe8d264247C72
 
Transaction Hash
Method
Block
From
To
Exec Transaction212360522024-11-21 12:17:5946 hrs ago1732191479IN
0xc1caF495...264247C72
0 ETH0.0049839431.22697078
Exec Transaction212360482024-11-21 12:17:1146 hrs ago1732191431IN
0xc1caF495...264247C72
0 ETH0.0021998529.92677794
Exec Transaction212360422024-11-21 12:15:5946 hrs ago1732191359IN
0xc1caF495...264247C72
0 ETH0.006921930.44952764
Exec Transaction212359622024-11-21 11:59:5946 hrs ago1732190399IN
0xc1caF495...264247C72
0 ETH0.0021046412.60038308
Exec Transaction212359322024-11-21 11:53:5946 hrs ago1732190039IN
0xc1caF495...264247C72
0 ETH0.0009830513.37348293
Exec Transaction212359192024-11-21 11:51:2346 hrs ago1732189883IN
0xc1caF495...264247C72
0 ETH0.004172914.78011948
Exec Transaction212357272024-11-21 11:12:5947 hrs ago1732187579IN
0xc1caF495...264247C72
0 ETH0.0051914714.3277812
Exec Transaction212357052024-11-21 11:08:1147 hrs ago1732187291IN
0xc1caF495...264247C72
0 ETH0.0096312112.94763287
Exec Transaction212356762024-11-21 11:02:1147 hrs ago1732186931IN
0xc1caF495...264247C72
0 ETH0.0026049414.04034761
Exec Transaction212356642024-11-21 10:59:3547 hrs ago1732186775IN
0xc1caF495...264247C72
0 ETH0.0050004511.80999137
Exec Transaction210217362024-10-22 14:32:1131 days ago1729607531IN
0xc1caF495...264247C72
0 ETH0.0029300734.58701768
Exec Transaction210217162024-10-22 14:28:1131 days ago1729607291IN
0xc1caF495...264247C72
0 ETH0.0099156536.21838401
Exec Transaction210217132024-10-22 14:27:3531 days ago1729607255IN
0xc1caF495...264247C72
0 ETH0.0118936636.26627023
Exec Transaction210217092024-10-22 14:26:4731 days ago1729607207IN
0xc1caF495...264247C72
0 ETH0.0281959139.00627467
Exec Transaction210217002024-10-22 14:24:5931 days ago1729607099IN
0xc1caF495...264247C72
0 ETH0.0124173842.16071432
Exec Transaction205121032024-08-12 11:01:47102 days ago1723460507IN
0xc1caF495...264247C72
0 ETH0.000718925.97502219
Exec Transaction205121002024-08-12 11:01:11102 days ago1723460471IN
0xc1caF495...264247C72
0 ETH0.000386455
Exec Transaction205120852024-08-12 10:57:59102 days ago1723460279IN
0xc1caF495...264247C72
0 ETH0.00045693.24586788
Exec Transaction205120592024-08-12 10:52:47102 days ago1723459967IN
0xc1caF495...264247C72
0 ETH0.000640186.91689238
Exec Transaction205120552024-08-12 10:51:59102 days ago1723459919IN
0xc1caF495...264247C72
0 ETH0.000655885
Exec Transaction205120342024-08-12 10:47:47102 days ago1723459667IN
0xc1caF495...264247C72
0 ETH0.001944386
Transfer205119722024-08-12 10:35:23102 days ago1723458923IN
0xc1caF495...264247C72
90 ETH0.000119494.37228219
Exec Transaction204984992024-08-10 13:26:59104 days ago1723296419IN
0xc1caF495...264247C72
0 ETH0.000325164
Exec Transaction204984922024-08-10 13:25:35104 days ago1723296335IN
0xc1caF495...264247C72
0 ETH0.001405561.68894515

Latest 5 internal transactions

Advanced mode:
Parent Transaction Hash Block From To
212357272024-11-21 11:12:5947 hrs ago1732187579
0xc1caF495...264247C72
65 ETH
212357052024-11-21 11:08:1147 hrs ago1732187291
0xc1caF495...264247C72
65.76879959 ETH
205120552024-08-12 10:51:59102 days ago1723459919
0xc1caF495...264247C72
10 ETH
205120342024-08-12 10:47:47102 days ago1723459667
0xc1caF495...264247C72
80 ETH
204984872024-08-10 13:24:35104 days ago1723296275  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.