Note
This is meant to be self-hosted. Follow the instructions below to deploy it to your own Cloudflare account.
Cloudflare Worker that provides a simple API for fetching ENS profiles and avatars. Built with ENSjs, heavily inspired by v3xlabs/enstate.
By default, all endpoints are cached for 10 minutes, then serve a stale response within the following 50 minutes while refreshing the cache in the background. Adjust these settings here. Avatars are cached for longer in most cases.
- GET
/name/:name
- Fetch a profile for an ENS name- Params (all optional):
texts
- keys of text records to fetch (comma-separated)coins
- coin types to fetch (comma-separated)
- Params (all optional):
- GET
/address/:address
- Fetch a profile for an Ethereum address, if it has a primary ENS name- Params (all optional):
texts
- keys of text records to fetch (comma-separated)coins
- coin types to fetch (comma-separated)
- Params (all optional):
- GET
/avatar/:name
- Fetch an avatar for an ENS name- Params (all optional):
width
- width of the avatar (default: 256)height
- height of the avatar (default: 256)
- Params (all optional):
- POST
/batch/names
- Resolve a list of addresses from ENS names- Body:
names
- array of ENS namescoinType
(optional) - coin type to resolve (default: 60)
- Body:
- POST
/batch/addresses
- Resolve a list of primary ENS names from ETH addresses- Body:
addresses
- array of ETH addresses
- Body:
Clone this repo
git clone https://github.com/gskril/ens-api.git
Install dependencies
yarn install
Set your environment variables (ETH RPC URL)
cp .dev.vars.example .dev.vars
Run the development server
yarn run dev
Sign into the Cloudflare CLI
npx wrangler login
Deploy the Worker
yarn run deploy
Set your ETH RPC environment variable
echo <VALUE> | npx wrangler secret put ETH_RPC
In order to enable avatar transformations, you will need to configure Cloudflare in a few ways:
- Under "Images" > "Transformations", navigate to the zone you want to use and enable transformations.
- Deploy this Worker to your Cloudflare account by following the instructions above.
- Make your Worker accessible from the zone (domain) you enabled in step 1.
- In the domain's DNS page, create an
A
record that points to192.0.2.0
with any name you want as a subdomain. - Under "Worker Routes", add a route that matches the subdomain you created and points to the Worker you deployed.
- In the domain's DNS page, create an