ETH Price: $2,062.58 (-0.66%)
 

Overview

ETH Balance

0 ETH

Eth Value

$0.00

More Info

Private Name Tags

Multichain Info

No addresses found
Transaction Hash
Method
Block
From
To
Withdraw234727152025-09-30 2:06:11138 days ago1759197971IN
0xD0dd36bD...3FE28DAf5
0 ETH0.000145381.28593977
Transfer230065412025-07-26 23:16:47203 days ago1753571807IN
0xD0dd36bD...3FE28DAf5
0.00793812 ETH0.000004720.19944254
Transfer228561472025-07-05 23:00:11224 days ago1751756411IN
0xD0dd36bD...3FE28DAf5
0.03791955 ETH0.00000670.2827826
Transfer223505562025-04-26 3:35:23295 days ago1745638523IN
0xD0dd36bD...3FE28DAf5
0.0536155 ETH0.000009760.4118287
Transfer219538292025-03-01 18:32:11350 days ago1740853931IN
0xD0dd36bD...3FE28DAf5
0.04646324 ETH0.000018860.79566673

Latest 25 internal transactions (View All)

Advanced mode:
Parent Transaction Hash Method Block
From
To
Dispatch234727152025-09-30 2:06:11138 days ago1759197971
0xD0dd36bD...3FE28DAf5
32.05238565 ETH
Dispatch232703932025-09-01 19:32:23166 days ago1756755143
0xD0dd36bD...3FE28DAf5
0.03848793 ETH
Dispatch231651682025-08-18 3:10:23181 days ago1755486623
0xD0dd36bD...3FE28DAf5
0.01936866 ETH
Dispatch230723012025-08-05 3:52:59194 days ago1754365979
0xD0dd36bD...3FE28DAf5
0.06630765 ETH
Dispatch230470502025-08-01 15:12:59197 days ago1754061179
0xD0dd36bD...3FE28DAf5
0.0273792 ETH
Dispatch229438742025-07-18 5:03:35212 days ago1752815015
0xD0dd36bD...3FE28DAf5
0.0194047 ETH
Dispatch228715142025-07-08 2:33:35222 days ago1751942015
0xD0dd36bD...3FE28DAf5
0.10415605 ETH
Dispatch227926382025-06-27 1:57:47233 days ago1750989467
0xD0dd36bD...3FE28DAf5
0.01914069 ETH
Dispatch227291562025-06-18 5:03:23242 days ago1750223003
0xD0dd36bD...3FE28DAf5
0.01908585 ETH
Dispatch226933492025-06-13 4:48:11247 days ago1749790091
0xD0dd36bD...3FE28DAf5
0.01911963 ETH
Dispatch226148752025-06-02 5:20:11258 days ago1748841611
0xD0dd36bD...3FE28DAf5
0.03871774 ETH
Dispatch224850142025-05-15 0:39:11276 days ago1747269551
0xD0dd36bD...3FE28DAf5
0.15754139 ETH
Dispatch222860342025-04-17 3:29:11304 days ago1744860551
0xD0dd36bD...3FE28DAf5
0.03873221 ETH
Dispatch221744792025-04-01 13:53:11319 days ago1743515591
0xD0dd36bD...3FE28DAf5
0.0192645 ETH
Dispatch220972952025-03-21 19:19:35330 days ago1742584775
0xD0dd36bD...3FE28DAf5
0.20719358 ETH
Dispatch217110592025-01-26 20:24:59384 days ago1737923099
0xD0dd36bD...3FE28DAf5
0.03862188 ETH
Dispatch215595172025-01-05 16:37:35405 days ago1736095055
0xD0dd36bD...3FE28DAf5
0.03872116 ETH
Dispatch214036172024-12-14 22:03:59427 days ago1734213839
0xD0dd36bD...3FE28DAf5
0.08514956 ETH
Dispatch212718712024-11-26 12:17:59445 days ago1732623479
0xD0dd36bD...3FE28DAf5
0.06573479 ETH
Dispatch212335712024-11-21 3:58:11451 days ago1732161491
0xD0dd36bD...3FE28DAf5
0.0390003 ETH
Dispatch210972782024-11-02 3:29:11470 days ago1730518151
0xD0dd36bD...3FE28DAf5
0.0194579 ETH
Dispatch210031972024-10-20 0:26:47483 days ago1729384007
0xD0dd36bD...3FE28DAf5
0.03889672 ETH
Dispatch209224142024-10-08 17:39:47494 days ago1728409187
0xD0dd36bD...3FE28DAf5
0.01932517 ETH
Dispatch207995332024-09-21 14:25:11511 days ago1726928711
0xD0dd36bD...3FE28DAf5
0.06538559 ETH
Dispatch207240042024-09-11 1:11:11522 days ago1726017071
0xD0dd36bD...3FE28DAf5
0.01923363 ETH
View All Internal Transactions
Loading...
Loading
Loading...
Loading
Cross-Chain Transactions
Withdrawals

Block Transaction Difficulty Gas Used Reward
View All Blocks Produced

Latest 25 from a total of 111 withdrawals (34.507680504 ETH withdrawn)

Validator Index Block Amount
602820234668222025-09-29 6:20:47139 days ago175912684732.014752474 ETH
602820234014002025-09-20 2:48:35148 days ago17583365150.01874025 ETH
602820233353832025-09-10 21:35:23157 days ago17575401230.018892931 ETH
602820232686512025-09-01 13:41:47166 days ago17567341070.019175185 ETH
602820232009812025-08-23 3:04:35176 days ago17559182750.019312751 ETH
602820231327742025-08-13 14:38:11185 days ago17550958910.019368661 ETH
602820230643552025-08-04 1:15:23195 days ago17542701230.066307659 ETH
602820229958432025-07-25 11:24:11204 days ago17534426510.019441082 ETH
602820229272112025-07-15 21:16:35214 days ago17526141950.019404708 ETH
602820228590052025-07-06 8:35:23224 days ago17517909230.066236504 ETH
602820227914062025-06-26 21:49:35233 days ago17509745750.019140695 ETH
602820227244522025-06-17 13:13:35242 days ago17501660150.019085857 ETH
602820226580812025-06-08 6:28:11252 days ago17493640910.01911963 ETH
602820225920022025-05-30 0:33:35261 days ago17485652150.019318999 ETH
602820225254522025-05-20 16:55:35270 days ago17477601350.019398744 ETH
602820224586472025-05-11 7:35:23280 days ago17469489230.019147349 ETH
602820223919982025-05-01 22:32:59289 days ago17461387790.065377259 ETH
602820223253342025-04-22 15:06:47298 days ago17453344070.019401286 ETH
602820222582062025-04-13 6:17:59308 days ago17445250790.019379339 ETH
602820221913302025-04-03 22:20:47317 days ago17437188470.019352874 ETH
602820221247562025-03-25 15:17:11326 days ago17429158310.019264508 ETH
602820220585072025-03-16 9:20:23336 days ago17421168230.019027182 ETH
602820219925372025-03-07 4:12:23345 days ago17413207430.064730926 ETH
602820219270482025-02-26 0:53:23354 days ago17405312030.019084985 ETH
602820218614962025-02-16 20:59:23363 days ago17397395630.019239878 ETH
View All Withdrawals

Transaction Hash Block Value Eth2 PubKey Valid
View All Deposits
Loading...
Loading

Minimal Proxy Contract for 0x933fbfeb4ed1f111d12a39c2ab48657e6fc875c6

Contract Name:
FeeRecipient

Compiler Version
v0.8.13+commit.abaa5c0e

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, BSL 1.1 license

Contract Source Code (Solidity Standard Json-Input format)

//SPDX-License-Identifier: BUSL-1.1
pragma solidity >=0.8.10;

import "./interfaces/IFeeDispatcher.sol";

contract FeeRecipient {
    /// @notice Constructor replay prevention
    bool internal initialized;
    /// @notice Address where funds are sent to be dispatched
    IFeeDispatcher internal dispatcher;
    /// @notice Public Key root assigned to this receiver
    bytes32 internal publicKeyRoot;

    error AlreadyInitialized();

    /// @notice Initializes the receiver
    /// @param _dispatcher Address that will handle the fee dispatching
    /// @param _publicKeyRoot Public Key root assigned to this receiver
    function init(address _dispatcher, bytes32 _publicKeyRoot) external {
        if (initialized) {
            revert AlreadyInitialized();
        }
        initialized = true;
        dispatcher = IFeeDispatcher(_dispatcher);
        publicKeyRoot = _publicKeyRoot;
    }

    /// @notice Empty calldata fallback
    receive() external payable {}

    /// @notice Non-empty calldata fallback
    fallback() external payable {}

    /// @notice Triggers a withdrawal by sending its funds + its public key root to the dispatcher
    /// @dev Can be called by any wallet as recipients are not parameters
    function withdraw() external {
        dispatcher.dispatch{value: address(this).balance}(publicKeyRoot);
    }

    /// @notice Retrieve the assigned public key root
    function getPublicKeyRoot() external view returns (bytes32) {
        return publicKeyRoot;
    }

    /// @notice retrieve the assigned withdrawer
    function getWithdrawer() external view returns (address) {
        return dispatcher.getWithdrawer(publicKeyRoot);
    }
}

//SPDX-License-Identifier: BUSL-1.1
pragma solidity >=0.8.10;

import "./libs/DispatchersStorageLib.sol";
import "./interfaces/IStakingContractFeeDetails.sol";
import "./interfaces/IFeeDispatcher.sol";

/// @title Consensus Layer Fee Recipient
/// @author Kiln
/// @notice This contract can be used to receive fees from a validator and split them with a node operator
contract ConsensusLayerFeeDispatcher is IFeeDispatcher {
    using DispatchersStorageLib for bytes32;

    event Withdrawal(
        address indexed withdrawer,
        address indexed feeRecipient,
        bytes32 pubKeyRoot,
        uint256 rewards,
        uint256 nodeOperatorFee,
        uint256 treasuryFee
    );

    error TreasuryReceiveError(bytes errorData);
    error FeeRecipientReceiveError(bytes errorData);
    error WithdrawerReceiveError(bytes errorData);
    error ZeroBalanceWithdrawal();
    error AlreadyInitialized();
    error InvalidCall();
    error NotImplemented();

    bytes32 internal constant STAKING_CONTRACT_ADDRESS_SLOT =
        keccak256("ConsensusLayerFeeRecipient.stakingContractAddress");
    uint256 internal constant BASIS_POINTS = 10_000;
    bytes32 internal constant VERSION_SLOT = keccak256("ConsensusLayerFeeRecipient.version");

    /// @notice Ensures an initialisation call has been called only once per _version value
    /// @param _version The current initialisation value
    modifier init(uint256 _version) {
        if (_version != VERSION_SLOT.getUint256() + 1) {
            revert AlreadyInitialized();
        }

        VERSION_SLOT.setUint256(_version);

        _;
    }

    /// @notice Constructor method allowing us to prevent calls to initCLFR by setting the appropriate version
    constructor(uint256 _version) {
        VERSION_SLOT.setUint256(_version);
    }

    /// @notice Initialize the contract by storing the staking contract
    /// @param _stakingContract Address of the Staking Contract
    function initCLD(address _stakingContract) external init(1) {
        STAKING_CONTRACT_ADDRESS_SLOT.setAddress(_stakingContract);
    }

    /// @notice Performs a withdrawal on this contract's balance
    function dispatch(bytes32) external payable {
        revert NotImplemented();
        /*
        uint256 balance = address(this).balance; // this has taken into account msg.value
        if (balance == 0) {
            revert ZeroBalanceWithdrawal();
        }
        IStakingContractFeeDetails stakingContract = IStakingContractFeeDetails(
            STAKING_CONTRACT_ADDRESS_SLOT.getAddress()
        );
        address withdrawer = stakingContract.getWithdrawerFromPublicKeyRoot(_publicKeyRoot);
        address operator = stakingContract.getOperatorFeeRecipient(_publicKeyRoot);
        address treasury = stakingContract.getTreasury();
        uint256 globalFee;

        if (balance >= 32 ether) {
            // withdrawing a healthy & exited validator
            globalFee = ((balance - 32 ether) * stakingContract.getGlobalFee()) / BASIS_POINTS;
        } else if (balance <= 16 ether) {
            // withdrawing from what looks like skimming
            globalFee = (balance * stakingContract.getGlobalFee()) / BASIS_POINTS;
        }

        uint256 operatorFee = (globalFee * stakingContract.getOperatorFee()) / BASIS_POINTS;

        (bool status, bytes memory data) = withdrawer.call{value: balance - globalFee}("");
        if (status == false) {
            revert WithdrawerReceiveError(data);
        }
        if (globalFee > 0) {
            (status, data) = treasury.call{value: globalFee - operatorFee}("");
            if (status == false) {
                revert FeeRecipientReceiveError(data);
            }
        }
        if (operatorFee > 0) {
            (status, data) = operator.call{value: operatorFee}("");
            if (status == false) {
                revert TreasuryReceiveError(data);
            }
        }
        emit Withdrawal(withdrawer, operator, balance - globalFee, operatorFee, globalFee - operatorFee);
        */
    }

    /// @notice Retrieve the staking contract address
    function getStakingContract() external view returns (address) {
        return STAKING_CONTRACT_ADDRESS_SLOT.getAddress();
    }

    /// @notice Retrieve the assigned withdrawer for the given public key root
    /// @param _publicKeyRoot Public key root to get the owner
    function getWithdrawer(bytes32 _publicKeyRoot) external view returns (address) {
        IStakingContractFeeDetails stakingContract = IStakingContractFeeDetails(
            STAKING_CONTRACT_ADDRESS_SLOT.getAddress()
        );
        return stakingContract.getWithdrawerFromPublicKeyRoot(_publicKeyRoot);
    }

    receive() external payable {
        revert InvalidCall();
    }

    fallback() external payable {
        revert InvalidCall();
    }
}

//SPDX-License-Identifier: MIT
pragma solidity >=0.8.10;

library DispatchersStorageLib {
    function getUint256(bytes32 position) internal view returns (uint256 data) {
        assembly {
            data := sload(position)
        }
    }

    function setUint256(bytes32 position, uint256 data) internal {
        assembly {
            sstore(position, data)
        }
    }

    function getAddress(bytes32 position) internal view returns (address data) {
        assembly {
            data := sload(position)
        }
    }

    function setAddress(bytes32 position, address data) internal {
        assembly {
            sstore(position, data)
        }
    }
}

// SPDX-License-Identifier: MIT
pragma solidity >=0.8.10;

interface IStakingContractFeeDetails {
    function getWithdrawerFromPublicKeyRoot(bytes32 _publicKeyRoot) external view returns (address);

    function getTreasury() external view returns (address);

    function getOperatorFeeRecipient(bytes32 pubKeyRoot) external view returns (address);

    function getGlobalFee() external view returns (uint256);

    function getOperatorFee() external view returns (uint256);
}

// SPDX-License-Identifier: MIT
pragma solidity >=0.8.10;

interface IFeeDispatcher {
    function dispatch(bytes32 _publicKeyRoot) external payable;

    function getWithdrawer(bytes32 _publicKeyRoot) external view returns (address);
}

//SPDX-License-Identifier: BUSL-1.1
pragma solidity >=0.8.10;

import "./libs/DispatchersStorageLib.sol";
import "./interfaces/IStakingContractFeeDetails.sol";
import "./interfaces/IFeeDispatcher.sol";

/// @title Execution Layer Fee Recipient
/// @author Kiln
/// @notice This contract can be used to receive fees from a validator and split them with a node operator
contract ExecutionLayerFeeDispatcher is IFeeDispatcher {
    using DispatchersStorageLib for bytes32;

    event Withdrawal(
        address indexed withdrawer,
        address indexed feeRecipient,
        bytes32 pubKeyRoot,
        uint256 rewards,
        uint256 nodeOperatorFee,
        uint256 treasuryFee
    );

    error TreasuryReceiveError(bytes errorData);
    error FeeRecipientReceiveError(bytes errorData);
    error WithdrawerReceiveError(bytes errorData);
    error ZeroBalanceWithdrawal();
    error AlreadyInitialized();
    error InvalidCall();

    bytes32 internal constant STAKING_CONTRACT_ADDRESS_SLOT =
        keccak256("ExecutionLayerFeeRecipient.stakingContractAddress");
    uint256 internal constant BASIS_POINTS = 10_000;
    bytes32 internal constant VERSION_SLOT = keccak256("ExecutionLayerFeeRecipient.version");

    /// @notice Ensures an initialisation call has been called only once per _version value
    /// @param _version The current initialisation value
    modifier init(uint256 _version) {
        if (_version != VERSION_SLOT.getUint256() + 1) {
            revert AlreadyInitialized();
        }

        VERSION_SLOT.setUint256(_version);

        _;
    }

    /// @notice Constructor method allowing us to prevent calls to initCLFR by setting the appropriate version
    constructor(uint256 _version) {
        VERSION_SLOT.setUint256(_version);
    }

    /// @notice Initialize the contract by storing the staking contract and the public key in storage
    /// @param _stakingContract Address of the Staking Contract
    function initELD(address _stakingContract) external init(1) {
        STAKING_CONTRACT_ADDRESS_SLOT.setAddress(_stakingContract);
    }

    /// @notice Performs a withdrawal on this contract's balance
    function dispatch(bytes32 _publicKeyRoot) external payable {
        uint256 balance = address(this).balance;
        if (balance == 0) {
            revert ZeroBalanceWithdrawal();
        }
        IStakingContractFeeDetails stakingContract = IStakingContractFeeDetails(
            STAKING_CONTRACT_ADDRESS_SLOT.getAddress()
        );
        address withdrawer = stakingContract.getWithdrawerFromPublicKeyRoot(_publicKeyRoot);
        address operator = stakingContract.getOperatorFeeRecipient(_publicKeyRoot);
        address treasury = stakingContract.getTreasury();
        uint256 globalFee = (balance * stakingContract.getGlobalFee()) / BASIS_POINTS;
        uint256 operatorFee = (globalFee * stakingContract.getOperatorFee()) / BASIS_POINTS;

        (bool status, bytes memory data) = withdrawer.call{value: balance - globalFee}("");
        if (status == false) {
            revert WithdrawerReceiveError(data);
        }
        if (globalFee > 0) {
            (status, data) = treasury.call{value: globalFee - operatorFee}("");
            if (status == false) {
                revert FeeRecipientReceiveError(data);
            }
        }
        if (operatorFee > 0) {
            (status, data) = operator.call{value: operatorFee}("");
            if (status == false) {
                revert TreasuryReceiveError(data);
            }
        }
        emit Withdrawal(
            withdrawer,
            operator,
            _publicKeyRoot,
            balance - globalFee,
            operatorFee,
            globalFee - operatorFee
        );
    }

    /// @notice Retrieve the staking contract address
    function getStakingContract() external view returns (address) {
        return STAKING_CONTRACT_ADDRESS_SLOT.getAddress();
    }

    /// @notice Retrieve the assigned withdrawer for the given public key root
    /// @param _publicKeyRoot Public key root to get the owner
    function getWithdrawer(bytes32 _publicKeyRoot) external view returns (address) {
        IStakingContractFeeDetails stakingContract = IStakingContractFeeDetails(
            STAKING_CONTRACT_ADDRESS_SLOT.getAddress()
        );
        return stakingContract.getWithdrawerFromPublicKeyRoot(_publicKeyRoot);
    }

    receive() external payable {
        revert InvalidCall();
    }

    fallback() external payable {
        revert InvalidCall();
    }
}

Settings
{
  "optimizer": {
    "enabled": true,
    "runs": 200
  },
  "outputSelection": {
    "*": {
      "*": [
        "evm.bytecode",
        "evm.deployedBytecode",
        "abi"
      ]
    }
  },
  "metadata": {
    "useLiteralContent": true
  }
}

Contract ABI

API
[{"inputs":[],"name":"AlreadyInitialized","type":"error"},{"stateMutability":"payable","type":"fallback"},{"inputs":[],"name":"getPublicKeyRoot","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getWithdrawer","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_dispatcher","type":"address"},{"internalType":"bytes32","name":"_publicKeyRoot","type":"bytes32"}],"name":"init","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"withdraw","outputs":[],"stateMutability":"nonpayable","type":"function"},{"stateMutability":"payable","type":"receive"}]

Block Uncle Number Difficulty Gas Used Reward
View All Uncles
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.