POL Price: $0.64822 (+4.94%)
 

Multichain Info

1 address found via
Transaction Hash
Method
Block
From
To
Exec Transaction605728252024-08-14 8:39:41120 days ago1723624781IN
Aura: Protocol Multi-sig
0 POL0.0022296725.00000005
Exec Transaction597144742024-07-23 14:42:41142 days ago1721745761IN
Aura: Protocol Multi-sig
0 POL1.0962821559.64205432
Exec Transaction597051942024-07-23 9:09:45142 days ago1721725785IN
Aura: Protocol Multi-sig
0 POL0.0047101230.00000196
Exec Transaction578743932024-06-07 12:52:44188 days ago1717764764IN
Aura: Protocol Multi-sig
0 POL0.0057171830.00310284
Exec Transaction569878872024-05-15 7:11:01211 days ago1715757061IN
Aura: Protocol Multi-sig
0 POL0.5541554130.0001431
Exec Transaction551821982024-03-28 16:20:34259 days ago1711642834IN
Aura: Protocol Multi-sig
0 POL0.03288316138.94685597
Exec Transaction537203212024-02-19 20:51:45296 days ago1708375905IN
Aura: Protocol Multi-sig
0 POL0.0071241570.12100318
Exec Transaction534630162024-02-13 7:05:00303 days ago1707807900IN
Aura: Protocol Multi-sig
0 POL0.0099883367.37309887
Exec Transaction529298802024-01-30 16:12:52317 days ago1706631172IN
Aura: Protocol Multi-sig
0 POL0.01878031170.16083465
Exec Transaction525356842024-01-20 7:26:28327 days ago1705735588IN
Aura: Protocol Multi-sig
0 POL0.0057023237.22190852
Exec Transaction521536742024-01-10 8:46:19337 days ago1704876379IN
Aura: Protocol Multi-sig
0 POL0.0097950963.96085039
Exec Transaction521533722024-01-10 8:34:32337 days ago1704875672IN
Aura: Protocol Multi-sig
0 POL0.0023579130.16391841
Exec Transaction520964182024-01-08 20:35:52338 days ago1704746152IN
Aura: Protocol Multi-sig
0 POL0.0031071929.00750477
Exec Transaction515917252023-12-26 20:34:44351 days ago1703622884IN
Aura: Protocol Multi-sig
0 POL0.0059601674.38584231
Exec Transaction515917242023-12-26 20:34:42351 days ago1703622882IN
Aura: Protocol Multi-sig
0 POL0.0061799677.12910762
Exec Transaction515917222023-12-26 20:34:38351 days ago1703622878IN
Aura: Protocol Multi-sig
0 POL1.2223073550.00918133
Exec Transaction499398712023-11-14 16:32:34394 days ago1699979554IN
Aura: Protocol Multi-sig
0 POL0.2274990536.67870068
Exec Transaction496966662023-11-08 14:22:18400 days ago1699453338IN
Aura: Protocol Multi-sig
0 POL0.02450698159.98186971
Exec Transaction487817872023-10-16 10:24:08423 days ago1697451848IN
Aura: Protocol Multi-sig
0 POL0.0101064693.26059642
Exec Transaction483096422023-10-04 8:15:45435 days ago1696407345IN
Aura: Protocol Multi-sig
0 POL0.5295102143.17235395
Exec Transaction478153122023-09-21 16:04:47448 days ago1695312287IN
Aura: Protocol Multi-sig
0 POL1.69244479137.49503407
Exec Transaction475739632023-09-15 13:58:30454 days ago1694786310IN
Aura: Protocol Multi-sig
0 POL0.5320242285.51721482
Exec Transaction469301782023-08-30 9:05:50470 days ago1693386350IN
Aura: Protocol Multi-sig
0 POL0.01250951115.42276865
Exec Transaction469007752023-08-29 15:18:38471 days ago1693322318IN
Aura: Protocol Multi-sig
0 POL0.03957308258.35379469
Exec Transaction466688602023-08-23 19:50:17476 days ago1692820217IN
Aura: Protocol Multi-sig
0 POL0.0103211997.64150742
View all transactions

Latest 1 internal transaction

Parent Transaction Hash Block From To
438631802023-06-13 11:57:59548 days ago1686657479  Contract Creation0 POL
Loading...
Loading

Similar Match Source Code
This contract matches the deployed Bytecode of the Source Code for Contract 0xb412684F...aB3ae124D
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 polygonscan.com on 2021-07-05
*/

/**
 *Submitted for verification at polygonscan.com on 2021-06-16
*/

// 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

598:1528:0:-:0;;;1450:42;1446:1;1440:8;1436:57;1630:66;1626:1;1613:15;1610:87;1607:2;;;1727:10;1724:1;1717:21;1766:4;1763:1;1756:15;1607:2;1819:14;1816:1;1813;1800:34;1917:1;1914;1898:14;1895:1;1883:10;1876:5;1863:56;1954:16;1951:1;1948;1933:38;2000:1;1991:7;1988:14;1985:2;;;2032:16;2029:1;2022:27;1985:2;2088:16;2085:1;2078:27

Swarm Source

ipfs://d1429297349653a4918076d650332de1a1068c5f3e07c5c82360c277770b9552

Block Transaction 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
[ 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.