Skip to content

Ether faucet server built with Go and Svelte.

License

Notifications You must be signed in to change notification settings

pmprete/eth-faucet

 
 

Repository files navigation

eth-faucet

Build Release Report Go License

The faucet is a web application with the goal of distributing small amounts of Ether in private and test networks.

Features

  • Configure the funding account using a private key or keystore
  • Implement CAPTCHA verification to prevent abuse
  • Rate-limit requests by ETH address and IP address to prevent spam
  • Prevent X-Forwarded-For spoofing by specifying the number of reverse proxies

Get started

Prerequisites

  • Go (version 1.17 or later)
  • Node.js

Installation

  1. Clone the repository and navigate to the app’s directory
git clone https://github.com/chainflag/eth-faucet.git
cd eth-faucet
  1. Bundle frontend with Vite
go generate

or

cd web
yarn install
yarn build
  1. Build Go project
go build -o eth-faucet

Usage

Use a private key

./eth-faucet -httpport 8080 -wallet.provider http://localhost:8545 -wallet.privkey privkey

Use a keystore

./eth-faucet -httpport 8080 -wallet.provider http://localhost:8545 -wallet.keyjson keystore -wallet.keypass password.txt

Configuration

You can configure the funding account by using environment variables instead of command-line flags:

export WEB3_PROVIDER=rpc_endpoint
export PRIVATE_KEY=hex_private_key

or

export WEB3_PROVIDER=rpc_endpoint
export KEYSTORE=keystore_path
echo "your_keystore_password" > `pwd`/password.txt

Then run the faucet application without the wallet command-line flags:

./eth-faucet -httpport 8080

Optional Flags

The following are the available command-line flags(excluding above wallet flags):

Flag Description Default Value
-httpport Listener port to serve HTTP connection 8080
-proxycount Count of reverse proxies in front of the server 0
-faucet.amount Number of Ethers to transfer per user request 1.0
-faucet.minutes Number of minutes to wait between funding rounds 1440
-faucet.name Network name to display on the frontend testnet
-faucet.symbol Token symbol to display on the frontend ETH
-hcaptcha.sitekey hCaptcha sitekey
-hcaptcha.secret hCaptcha secret

Yoou can get hCaptcha at https://www.hcaptcha.com/

Docker build

docker build --tag eth-faucet:1.2.0 .

Docker deployment

docker run -d -p 8080:8080 -e WEB3_PROVIDER=rpc_endpoint -e PRIVATE_KEY=hex_private_key eth-faucet:1.2.0 -faucet.symbol=NXRA -faucet.name=nexera

or

docker run -d -p 8080:8080 -e WEB3_PROVIDER=rpc_endpoint -e KEYSTORE=keystore_path -v `pwd`/keystore:/app/keystore -v `pwd`/password.txt:/app/password.txt eth-faucet:1.2.0 -faucet.symbol=NXRA -faucet.name=nexera

If running locally rpc_endpoint should be http://host.docker.internal:8545

Add a network

In order to add a network you should go to server.go and add the network in the the chainId array

chainIDMap = map[string]int{"sepolia": 11155111, "holesky": 17000, "nexera": 32382}

To select it use the faucet.name flag.

License

Distributed under the MIT License. See LICENSE for more information.

About

Ether faucet server built with Go and Svelte.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Go 79.0%
  • Svelte 16.6%
  • Dockerfile 1.7%
  • JavaScript 1.6%
  • HTML 1.1%