Awesome
Spook
This Ethereum RPC request mixer is a proof of concept that uses the Nym network to anonymize RPC requests.
This is useful if:
- You need to protect your real IP location of the
entry
node. - You want to unblock yourself, if you're in a sanctioned country and you're using Metamask
- Your IP is not known by the
exit
node. Where you are in the world is not visible for anyone, it's hidden behind the Nym network. - If the
exit
node is compromised, it does not reveal your IP address.
However, your exit node's IP address will be visible to the Ethereum node, but the entry
node's IP address will be hidden behind the Nym network. Also, the exit
node can censor your requests if it wants to.
You can use this as:
- RPC URL for Metamask or other wallets to anonymize your requests (prevent real IP logging, unblock sanctioned countries)
- local RPC URL for CLI utilities (like
cast
)
How it works
This leverages the Nym network to mix RPC requests through their network of mix nodes.
This project consists of 2 utilities:
entry
- receives the usual RPC requests and forwards them to the Nym networkexit
- receives the requests from the Nym network and forwards them to the Ethereum node
Each of the utilities can run on different machines. If you run them on the same machine your IP is not anonymized from the Ethereum RPC provider. Between these utilities sits the Nym network, which mixes the sent packets to anonymize the requests.
The Ethereum node will see the IP of the machine running the exit
utility. The user can remain anonymous and hidden behind the Nym network. Even multiple clients can use the same exit
utility.
The user can use a public entry
utility, but running your own is the only way to be sure that your requests are not logged.
The orange boxes were already created by Nym; this repository provides the blue boxes: the entry
and the exit
.
The entry
receives requests from the user and relays the requests through the Nym network to the exit
, which then forwards the requests to the Ethereum node.
Running the app
Manual setup
For the full system to work, you will run 4 programs:
- 2 Nym clients (one for the
entry
and one for theexit
) - the
entry
which receives requests from the user - the
exit
which relays the requests to the Ethereum node (or RPC provider)
Additionally, you need an RPC provider or an Ethereum node to forward the requests to.
A simplified example of how this can be set up is:
Install the Nym WebSocket client
You can install the Nym WebSocket client by downloading the binary from the releases page or by building it from source.
Set up the exit
node
This is the exit node of the pipeline. This is the machine that will receive the requests from the Nym network and forward them to the Ethereum node.
The exit
utility needs to be run on a machine that can forward requests to an Ethereum node. To receive the requests from the Nym network, it needs to run the Nym WebSocket client.
Once the Nym WebSocket client is installed, you can initialize it with the following command:
nym-client init --id exit-node --port 3001
This will create a new configuration that makes the WebSocket client listen on port 3001
and use the exit-node
identity.
The last lines of the output will be the exit-node
's address. You'll need this when you start the entry
to know to who to send the messages.
You can go ahead and start the Nym client after you create the config:
nym-client run --id exit-node
You need to start Spook's exit module, do this by cloning the repo and building the project:
git clone https://github.com/EdenBlockVC/spook
cd spook
yarn
yarn build
Once that's done, you need to set the ETH_RPC_URL
environment variable to the URL of the Ethereum node you want to forward the requests.
For example, if you want to forward the requests to a local node running on https://eth.llamarpc.com
you can set the ETH_RPC_URL
environment variable to:
export ETH_RPC_URL=https://eth.llamarpc.com
To set the NYM_HOST_URL
environment variable to the URL of the Nym WebSocket client, by default this has the value:
export NYM_HOST_URL=ws://localhost:3001
If the Nym WebSocket client is on a different machine, you can set the NYM_HOST_URL
environment variable to the host of the Nym WebSocket client.
Bringing this together you can set the environment variables and start the exit
utility with:
export ETH_RPC_URL=https://eth.llamarpc.com
export NYM_HOST_URL=ws://localhost:3001
yarn start:exit
Once it starts, it displays the address to which the entry
should send the requests.
The exit node's address is:
CYR3uUj9vDkRvCVqZotFZwCqdhef4KP8Dk74LBVeXG7A.CZuVqwNKqjjj6yzFFmhkMm5joh1REzs6eiEfqkjT2Vtw@7Zh1Sz5dXpA6s53CbtcdqhQhLqwf4cLynL7KqHKcjrG4
You should specify this address as the target address when running the entry utility.
Your exit utility is ready to make requests to the Ethereum RPC provider.
Set up the entry
node
This is the entry node of the pipeline. This is the machine that will receive the requests from the user and forward them to the Nym network.
The entry
utility needs to send the requests to the Nym network. Thus it needs to run the Nym WebSocket client.
Once the Nym WebSocket client is installed, you can initialize it with the following command:
nym-client init --id entry-node --port 3000
This will create a new configuration that makes the WebSocket client listen on port 3000
and use the entry-node
identity.
You can go ahead and start the Nym client after you create the config:
nym-client run --id entry-node
You need to start Spook's entry
module, do this by cloning the repo and building the project:
git clone https://github.com/EdenBlockVC/spook
cd spook
yarn
yarn build
The entry
utility will listen on port 8545
for Ethereum RPC requests and will relay them to the Nym network, where the exit
will receive and process them. You need to specify the exit node address to know where to relay these requests. This is the address that the exit
displayed when it started.
export EXIT_NODE_ADDRESS={YOUR_EXIT_NODE_ADDRESS}
To set the NYM_HOST_URL
environment variable to the URL of the Nym WebSocket client, by default this has the value:
export NYM_HOST_URL=ws://localhost:3000
Bringing this together you set the exit node's address and can also specify a different Nym WebSocket client host and start the entry
utility with:
export EXIT_NODE_ADDRESS={YOUR_EXIT_NODE_ADDRESS}
export NYM_HOST_URL=ws://localhost:3000
yarn start:entry
Once this started you should have 4 terminals running:
- 1 Nym WebSocket client on the
exit
node - 1
exit
utility - 1 Nym WebSocket client on the
entry
node - 1
entry
utility
Docker
You can try using an already set up exit node and only build the local node.
To do that find out the address of the exit node from the provider.
Create a copy of the env-entry.sample
file and name it env-entry
.
cp env-entry.sample env-entry
Then edit the env-entry
file and set the EXIT_NODE_ADDRESS
to the address of the exit node.
Then build the docker image with the following command:
docker build -t spook-entry .
Once you built the image and set up the env-entry
file, you can run the docker image with the following command:
docker run --env-file env-entry -p 8545:8545 -d spook
Usage
Cast
Once everything is set up, you can try running a simple request to see if everything works.
For this, I am using cast
, which is a simple CLI utility to send Ethereum RPC requests.
On the machine running the entry
utility, you can:
ETH_RPC_URL=http://localhost:8545 cast block-number
This request will be relayed to the Nym network and forwarded to the Ethereum node running on the exit
machine. Once the response is received, it will be relayed back to the entry
and displayed.
Metamask
Also works seamlessly with Metamask.
Once you set everything up and the entry utility is running on your local machine, just change Metamask to use the local RPC.
You can use Metamask as you normally would, but the requests will be relayed through the Nym network.