/el-sync-driver

A little tool to guide one or more Ethereum's Execution Layer clients to sync the network using an existing Consensus Layer client

Primary LanguageJavaScriptMIT LicenseMIT

EL Sync Driver

This tool is able to drive multiple Execution Layer Clients sync process. It emulates a Consensus Layer Client for each EL by using an existing CL as source of truth.

The tool is designed to minimize the changes on the existing CL client. It only requires to consume standard BeaconNode rest API, thus no changes in CL configuration are required (not even client restart) as long as rest APIs are already enabled.

graph LR
    B(EL-sync-driver) -- block/head<br />fork_choice --> C[CL - REST API]
    C -- beacon block head<br />finalized\justified data--> B
    B -- engine_newPayload<br />engine_forkChoiceUpdated --> D[EL1 - engine API]
    B --> E[EL2 - engine API]
    B --> F[ELn - engine API]
Loading

Installation

Clone the repository and install the dependencies:

git clone https://github.com/tbenr/el-sync-driver.git
cd el-sync-driver
npm install

npm install is not needed if you plan to use docker.

Configuration

Edit config.json and specify a Consensus Layer rest API endpoint and the list of Execution Layers engine api endpoint and secret file

{
    "ClRestApiEndpoint": "http://localhost:5051",
    "ElJsonrpcEndpoints": [
        {
            "endpoint": "http://localhost:8551",
            "jwtSecretFile": "/path/to/secret"
        }
    ]
}

If you want to use docker, edit docker-compose.yml to mount secret file(s) in the container.

Usage

Start by running:

npm start

or by using docker-compose:

docker-compose up

output while driving

image

Disclaimer

This is an experimental tool and is provided as-is, without any kind of warranty or support. Use it at your own risk. The author and contributors of this project are not responsible for any damages or losses that may occur from the use of this tool. It is recommended to thoroughly review and test the code before using it in any production environment.

Usage Notice

Please note that this tool is intended for educational and experimental purposes only. It is not recommended to use this tool in any critical or production systems. The tool may have limitations, known issues, or security vulnerabilities that have not been thoroughly tested or addressed.

Contributing

Contributions to this project are welcome, but please understand that there may be no active maintenance or support for this tool. If you encounter any issues or have suggestions, you can submit them as GitHub issues, but there is no guarantee that they will be addressed or resolved.

License

This project is licensed under the MIT License. See the LICENSE file for details.