More Info
Private Name Tags
ContractCreator
Multichain Info
No addresses found
Latest 7 from a total of 7 transactions
Transaction Hash |
Method
|
Block
|
From
|
To
|
|||||
---|---|---|---|---|---|---|---|---|---|
Execute | 20847239 | 165 days ago | IN | 0 ETH | 0.00036256 | ||||
Execute | 20847219 | 165 days ago | IN | 0 ETH | 0.00056562 | ||||
Transfer | 20791581 | 173 days ago | IN | 0.004 ETH | 0.00040283 | ||||
Transfer | 20733597 | 181 days ago | IN | 0.0001 ETH | 0.0000612 | ||||
Execute | 20733503 | 181 days ago | IN | 0 ETH | 0.00033854 | ||||
Transfer | 20733426 | 181 days ago | IN | 0.0005 ETH | 0.00007736 | ||||
Transfer | 20733373 | 181 days ago | IN | 0.002 ETH | 0.00012165 |
Loading...
Loading
Minimal Proxy Contract for 0x93a1222f62de5b6012af8b4fdd3d2053c5500934
Similar Match Source Code This contract matches the deployed Bytecode of the Source Code for Contract 0xB7D7Ccd0...4c391B248 The constructor portion of the code might be different and could alter the actual behaviour of the contract
Contract Name:
Proxy
Compiler Version
v0.8.21+commit.d9974bed
Optimization Enabled:
No with 200 runs
Other Settings:
paris EvmVersion
Contract Source Code (Solidity Standard Json-Input format)
// SPDX-License-Identifier: BUSL-1.1 pragma solidity ^0.8.21; import {ERC6551Proxy} from "solady/accounts/ERC6551Proxy.sol"; contract Proxy is ERC6551Proxy { constructor(address _implementation) ERC6551Proxy(_implementation) {} }
// SPDX-License-Identifier: MIT pragma solidity ^0.8.4; /// @notice Relay proxy for upgradeable ERC6551 accounts. /// @author Solady (https://github.com/vectorized/solady/blob/main/src/accounts/ERC6551Proxy.sol) /// @author ERC6551 team (https://github.com/erc6551/reference/blob/main/src/examples/upgradeable/ERC6551AccountProxy.sol) /// /// @dev Note: This relay proxy is required for upgradeable ERC6551 accounts. /// /// ERC6551 clone -> ERC6551Proxy (relay) -> ERC6551 account implementation. /// /// This relay proxy also allows for correctly revealing the /// "Read as Proxy" and "Write as Proxy" tabs on Etherscan. /// /// After using the registry to deploy a ERC6551 clone pointing to this relay proxy, /// users must send 0 ETH to the clone before clicking on "Is this a proxy?" on Etherscan. /// Verification of this relay proxy on Etherscan is optional. contract ERC6551Proxy { /*´:°•.°+.*•´.*:˚.°*.˚•´.°:°•.°•.*•´.*:˚.°*.˚•´.°:°•.°+.*•´.*:*/ /* IMMUTABLES */ /*.•°:°.´+˚.*°.˚:*.´•*.+°.•°:´*.´•*.•°.•°:°.´:•˚°.*°.˚:*.´+°.•*/ /// @dev The default implementation. bytes32 internal immutable _defaultImplementation; /*´:°•.°+.*•´.*:˚.°*.˚•´.°:°•.°•.*•´.*:˚.°*.˚•´.°:°•.°+.*•´.*:*/ /* STORAGE */ /*.•°:°.´+˚.*°.˚:*.´•*.+°.•°:´*.´•*.•°.•°:°.´:•˚°.*°.˚:*.´+°.•*/ /// @dev The ERC-1967 storage slot for the implementation in the proxy. /// `uint256(keccak256("eip1967.proxy.implementation")) - 1`. bytes32 internal constant _ERC1967_IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc; /*´:°•.°+.*•´.*:˚.°*.˚•´.°:°•.°•.*•´.*:˚.°*.˚•´.°:°•.°+.*•´.*:*/ /* CONSTRUCTOR */ /*.•°:°.´+˚.*°.˚:*.´•*.+°.•°:´*.´•*.•°.•°:°.´:•˚°.*°.˚:*.´+°.•*/ constructor(address defaultImplementation) payable { _defaultImplementation = bytes32(uint256(uint160(defaultImplementation))); } /*´:°•.°+.*•´.*:˚.°*.˚•´.°:°•.°•.*•´.*:˚.°*.˚•´.°:°•.°+.*•´.*:*/ /* FALLBACK */ /*.•°:°.´+˚.*°.˚:*.´•*.+°.•°:´*.´•*.•°.•°:°.´:•˚°.*°.˚:*.´+°.•*/ fallback() external payable virtual { bytes32 implementation; assembly { mstore(0x40, returndatasize()) // Optimization trick to change `6040608052` into `3d604052`. implementation := sload(_ERC1967_IMPLEMENTATION_SLOT) } if (implementation == bytes32(0)) { implementation = _defaultImplementation; assembly { // Only initialize if the calldatasize is zero, so that staticcalls to // functions (which will have 4-byte function selectors) won't revert. // Some users may be fine without Etherscan proxy detection and thus may // choose to not initialize the ERC1967 implementation slot. if iszero(calldatasize()) { sstore(_ERC1967_IMPLEMENTATION_SLOT, implementation) } } } assembly { calldatacopy(returndatasize(), returndatasize(), calldatasize()) // forgefmt: disable-next-item if iszero(delegatecall(gas(), implementation, returndatasize(), calldatasize(), codesize(), returndatasize())) { returndatacopy(0x00, 0x00, returndatasize()) revert(0x00, returndatasize()) } returndatacopy(0x00, 0x00, returndatasize()) return(0x00, returndatasize()) } } }
{ "evmVersion": "paris", "optimizer": { "enabled": false, "runs": 200 }, "outputSelection": { "*": { "*": [ "evm.bytecode", "evm.deployedBytecode", "devdoc", "userdoc", "metadata", "abi" ] } }, "libraries": {} }
Contract ABI
API[{"inputs":[{"internalType":"address","name":"_implementation","type":"address"}],"stateMutability":"nonpayable","type":"constructor"},{"stateMutability":"payable","type":"fallback"}]
Loading...
Loading
Loading...
Loading
Loading...
Loading
Loading...
Loading
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.