2022-11-23 17:11:38 +01:00
# Nimbus Verified Proxy
2022-09-16 15:25:07 +02:00
2022-11-23 17:11:38 +01:00
[![Nimbus Verified Proxy CI ](https://github.com/status-im/nimbus-eth1/actions/workflows/nimbus_verified_proxy.yml/badge.svg )](https://github.com/status-im/nimbus-eth1/actions/workflows/nimbus_verified_proxy.yml)
2022-09-30 12:56:16 +02:00
![Stability: experimental ](https://img.shields.io/badge/stability-experimental-orange.svg )
[![License: Apache ](https://img.shields.io/badge/license-Apache%202.0-blue.svg )](https://opensource.org/licenses/Apache-2.0)
[![License: MIT ](https://img.shields.io/badge/license-MIT-blue.svg )](https://opensource.org/licenses/MIT)
[![Discord: Nimbus ](https://img.shields.io/badge/Discord-Nimbus-blue.svg )](https://discord.gg/XRxWahP)
[![Status: #nimbus-general ](https://img.shields.io/badge/Status-nimbus--general-blue.svg )](https://join.status.im/nimbus-general)
2022-11-23 17:11:38 +01:00
The Nimbus Verified Proxy is a very efficient light client for the Ethereum
2022-11-18 14:37:22 +01:00
PoS network.
2022-09-30 12:56:16 +02:00
2022-11-18 14:37:22 +01:00
It exposes the standard [Ethereum JSON RPC Execution API ](https://github.com/ethereum/execution-apis )
and proxies the API calls to a configured, untrusted, web3 data provider.
Responses from the web3 data provider are verified by requesting Merkle proofs
and checking them against the state hash.
The [consensus p2p light client ](https://github.com/ethereum/consensus-specs/tree/dev/specs/altair/light-client )
is used to efficiently follow the tip of the consensus chain and
have access to the latest state hash.
2022-11-23 17:11:38 +01:00
As such the Nimbus Verified Proxy turns the untrusted web3 data provider
2022-11-18 14:37:22 +01:00
into a verified data source, and it can be directly used by any wallet that
relies on the Ethereum JSON RPC Execution API.
2022-11-23 17:11:38 +01:00
### Build the Nimbus Verified Proxy from source
2022-09-30 12:56:16 +02:00
```bash
2022-11-18 14:37:22 +01:00
# Clone the nimbus-eth1 repository
2022-09-30 12:56:16 +02:00
git clone git@github .com:status-im/nimbus-eth1.git
cd nimbus-eth1
2022-11-18 14:37:22 +01:00
# Run the build process
2022-11-23 17:11:38 +01:00
make nimbus_verified_proxy
2022-09-30 12:56:16 +02:00
# See available command line options
2022-11-23 17:11:38 +01:00
./build/nimbus_verified_proxy --help
2022-09-30 12:56:16 +02:00
```
2022-11-23 17:11:38 +01:00
### Run the Nimbus Verified Proxy
2022-11-18 14:37:22 +01:00
Two options need to be explicitly configured by the user:
2022-09-30 12:56:16 +02:00
2022-11-23 17:11:38 +01:00
* `--trusted-block-root` : The consensus light client starts syncing from a trusted block. This trusted block should be somewhat recent ([~1-2 weeks ](https://github.com/ethereum/consensus-specs/blob/dev/specs/phase0/weak-subjectivity.md )) and needs to be configured each time when starting the Nimbus Verified Proxy.
2022-09-30 12:56:16 +02:00
2022-11-18 14:37:22 +01:00
* `--web3-url` - As the proxy does not use any storage, it needs access to an Ethereum JSON RPC endpoint to provide the requested data. This can be a regular full node, or an external web3 data provider like
[Alchemy ](https://www.alchemy.com/ ).
2022-09-30 12:56:16 +02:00
2022-11-18 14:37:22 +01:00
A first requirement for the web3 data provider is that it must support the standard Ethereum JSON RPC Execution API, including the [eth_getProof ](https://eips.ethereum.org/EIPS/eip-1186 ) call.
The latter is necessary to validate the provided data against the light client.
2022-09-30 12:56:16 +02:00
2022-11-18 14:37:22 +01:00
A second requirement is that data served from provider needs to match with
2022-11-23 17:11:38 +01:00
the ```--network` `` option configured for the Nimbus Verified Proxy. By default the proxy is configured to work on mainnet. Thus, the configured provider needs to serve mainnet data.
2022-09-30 12:56:16 +02:00
This is verified on start-up by querying the provider its `eth_chainId` endpoint, and comparing the
2022-11-23 17:11:38 +01:00
received chain id with the one configured locally. If this validation fails, the Nimbus Verified Proxy will quit.
2022-11-18 14:37:22 +01:00
> Note: Infura currently does not support the `eth_getProof` call.
#### Obtaining a trusted block root
A block root may be obtained from a trusted beacon node or from a trusted provider.
* Trusted beacon node:
The REST interface must be enabled on the trusted beacon node (`--rest --rest-port=5052` for Nimbus).
```sh
curl -s "http://localhost:5052/eth/v1/beacon/headers/finalized" | \
jq -r '.data.root'
```
* Trusted provider, e.g. Beaconcha.in:
2022-09-30 12:56:16 +02:00
2022-11-18 14:37:22 +01:00
On the [beaconcha.in ](https://beaconcha.in ) website ([Goerli ](https://prater.beaconcha.in )), navigate to the `Epochs` section and select a recent `Finalized` epoch. Then, scroll down to the bottom of the page. If the bottom-most slot has a `Proposed` status, copy its `Root Hash` . Otherwise, for example if the bottom-most slot was `Missed` , go back and pick a different epoch.
2022-09-30 12:56:16 +02:00
2022-11-18 14:37:22 +01:00
#### Start the process
To start the proxy for the Goerli network, run the following command (inserting your own trusted block root and replacing the web3-url to your provider of choice):
```bash
# From the nimbus-eth1 repository
TRUSTED_BLOCK_ROOT=0x1234567890123456789012345678901234567890123456789012345678901234 # Replace this
2022-11-23 17:11:38 +01:00
./build/nimbus_verified_proxy \
2022-11-18 14:37:22 +01:00
--network=goerli \
--trusted-block-root=${TRUSTED_BLOCK_ROOT} \
--web3-url="wss://eth-goerli.g.alchemy.com/v2/< ApiKey > "
```
2022-11-23 17:11:38 +01:00
### Using the Nimbus Verified Proxy with existing Wallets
The Nimbus Verified Proxy exposes the standard Ethereum JSON RPC Execution API and can thus be used
2022-11-18 14:37:22 +01:00
as drop-in replacement for any Wallet that relies on this API.
By doing so, it turns an untrusted web3 data provider into a verified data source.
2022-11-23 17:11:38 +01:00
The Nimbus Verified Proxy has been tested in combination with MetaMask.
2022-11-18 14:37:22 +01:00
The [MetaMask configuration page ](./docs/metamask_configuration.md ) explains how to configure the proxy, and how to configure MetaMask to make use of the proxy.
2022-11-23 17:11:38 +01:00
### Update and rebuild the Nimbus Verified Proxy
2022-09-30 12:56:16 +02:00
```bash
# From the nimbus-eth1 repository
git pull
# To bring the git submodules up to date
make update
2022-11-23 17:11:38 +01:00
make nimbus_verified_proxy
2022-09-30 12:56:16 +02:00
```
2022-11-23 17:11:38 +01:00
### Run the Nimbus Verified Proxy test suite
2022-09-30 12:56:16 +02:00
```bash
# From the nimbus-eth1 repository
2022-11-23 17:11:38 +01:00
make nimbus-verified-proxy-test
2022-09-30 12:56:16 +02:00
```
### Windows support
2022-11-23 17:11:38 +01:00
Follow the steps outlined [here ](../README.md#windows ) to build Nimbus Verified Proxy on Windows.
2022-09-30 12:56:16 +02:00
## For Developers
When working on this repository, you can run the `env.sh` script to run a
command with the right environment variables set. This means the vendored
Nim and Nim modules will be used, just as when you use `make` .
E.g.:
```bash
# start a new interactive shell with the right env vars set
./env.sh bash
```
## License
Licensed and distributed under either of
* MIT license: [LICENSE-MIT ](../LICENSE-MIT ) or http://opensource.org/licenses/MIT
or
* Apache License, Version 2.0, ([LICENSE-APACHEv2 ](../LICENSE-APACHEv2 ) or http://www.apache.org/licenses/LICENSE-2.0)
at your option. These files may not be copied, modified, or distributed except according to those terms.