2020-10-02 09:42:19 +00:00
|
|
|
# Validator Client API: Authorization Header
|
|
|
|
|
|
|
|
## Overview
|
|
|
|
|
|
|
|
The validator client HTTP server requires that all requests have the following
|
|
|
|
HTTP header:
|
|
|
|
|
|
|
|
- Name: `Authorization`
|
2022-01-30 23:22:04 +00:00
|
|
|
- Value: `Bearer <api-token>`
|
2020-10-02 09:42:19 +00:00
|
|
|
|
|
|
|
Where `<api-token>` is a string that can be obtained from the validator client
|
|
|
|
host. Here is an example `Authorization` header:
|
|
|
|
|
|
|
|
```
|
2022-01-30 23:22:04 +00:00
|
|
|
Authorization: Bearer api-token-0x03eace4c98e8f77477bb99efb74f9af10d800bd3318f92c33b719a4644254d4123
|
2020-10-02 09:42:19 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
## Obtaining the API token
|
|
|
|
|
|
|
|
The API token is stored as a file in the `validators` directory. For most users
|
2020-11-23 23:54:03 +00:00
|
|
|
this is `~/.lighthouse/{network}/validators/api-token.txt`. Here's an
|
2020-10-02 09:42:19 +00:00
|
|
|
example using the `cat` command to print the token to the terminal, but any
|
|
|
|
text editor will suffice:
|
|
|
|
|
|
|
|
```
|
|
|
|
$ cat api-token.txt
|
|
|
|
api-token-0x03eace4c98e8f77477bb99efb74f9af10d800bd3318f92c33b719a4644254d4123
|
|
|
|
```
|
|
|
|
|
|
|
|
|
2021-09-03 02:41:10 +00:00
|
|
|
When starting the validator client it will output a log message containing the path
|
|
|
|
to the file containing the api token.
|
2020-10-02 09:42:19 +00:00
|
|
|
|
|
|
|
```
|
2021-09-03 02:41:10 +00:00
|
|
|
Sep 28 19:17:52.615 INFO HTTP API started api_token_file: "$HOME/prater/validators/api-token.txt", listen_address: 127.0.0.1:5062
|
2020-10-02 09:42:19 +00:00
|
|
|
```
|
|
|
|
|
2022-01-30 23:22:04 +00:00
|
|
|
The _path_ to the API token may also be fetched from the HTTP API itself (this endpoint is the only
|
|
|
|
one accessible without the token):
|
|
|
|
|
|
|
|
```bash
|
|
|
|
curl http://localhost:5062/lighthouse/auth
|
|
|
|
```
|
|
|
|
|
|
|
|
Response:
|
|
|
|
|
|
|
|
```json
|
|
|
|
{
|
|
|
|
"token_path": "/home/karlm/.lighthouse/prater/validators/api-token.txt"
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2020-10-02 09:42:19 +00:00
|
|
|
## Example
|
|
|
|
|
|
|
|
Here is an example `curl` command using the API token in the `Authorization` header:
|
|
|
|
|
|
|
|
```bash
|
2022-01-30 23:22:04 +00:00
|
|
|
curl localhost:5062/lighthouse/version -H "Authorization: Bearer api-token-0x03eace4c98e8f77477bb99efb74f9af10d800bd3318f92c33b719a4644254d4123"
|
2020-10-02 09:42:19 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
The server should respond with its version:
|
|
|
|
|
|
|
|
```json
|
|
|
|
{"data":{"version":"Lighthouse/v0.2.11-fc0654fbe+/x86_64-linux"}}
|
|
|
|
```
|