Skip to main content

Use the REST API

View the REST API

View the REST API documentation for information about the available API methods.

Enable the REST API service

Enable the REST API service from the command line by setting the --rest-api-enabled command line option to true.

You can also interact with APIs using Swagger UI by enabling the API documentation endpoint.

warning

Only trusted parties should access the REST API. Do not directly expose these APIs publicly on production nodes.

Interact with Teku APIs using the web browser by setting the --rest-api-docs-enabled command line option to true.

Access the APIs at http:<interface>:<port>/swagger-ui where:

The default location is http://localhost:5051/swagger-ui.

You can also use tools such as Postman or cURL to interact with Teku APIs.

curl -X GET "http://localhost:5051/eth/v1/node/identity"

Configure the API for network interfaces and host allowlist

You can use the rest-api-host-allowlist and rest-api-interface options to control which hosts and network interfaces Teku's REST API responds to. Configure the API to listen on specific IP addresses or all interfaces with rest-api-interface and control which hosts can connect using rest-api-host-allowlist:

ConfigurationInterfaceAllowlistResult
Listen on all IP addresses and allow all hostsrest-api-interface="0.0.0.0"rest-api-host-allowlist=["*"]Enables connections from any address, such as localhost (127.0.0.1) or 10.0.0.1.
Listen on a specific IP address (10.0.0.1) and allow all hostsrest-api-interface="10.0.0.1"rest-api-host-allowlist=["*"]Only the specified IP (10.0.0.1) can connect, and attempts from localhost (127.0.0.1) will fail.
Listen on all IP addresses but allow only localhostrest-api-interface="0.0.0.0"rest-api-host-allowlist=["127.0.0.1"]Only localhost (127.0.0.1) can connect; other IP addresses (e.g., 10.0.0.1) will receive a 403 error.
Listen on a specific IP address (10.0.0.1) but allow only localhost (127.0.0.1)rest-api-interface="10.0.0.1"rest-api-host-allowlist=["127.0.0.1"]Neither can connect. localhost can't reach the server, and 10.0.0.1 is blocked.

Enable the validator client API

The validator client API allows you to call the key manager API endpoints and is enabled separately from the REST API methods.

Enable the validator client API service from the command line by including the --validator-api-enabled command line option.

When enabling the validator client API, you must create a keystore. Set the keystore using --validator-api-keystore-file and the password file for the keystore using --validator-api-keystore-password-file.

Example
teku --validator-api-enabled --validator-api-keystore-file=validator_keystore.p12 --validator-api-keystore-password-file=validator_keystore_pass.txt

The OpenAPI specifications for the validator client API are available at /swagger-docs when the --validator-api-docs-enabled option is set to true. The /swagger-docs endpoint defines the API if code generators are in use.

When enabling the API documentation endpoint, specify: