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]
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.
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.
Start by running:
npm start
or by using docker-compose:
docker-compose up
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.
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.
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.
This project is licensed under the MIT License. See the LICENSE file for details.