Fauna Core HTTP API
Download OpenAPI specification:Download
You can use the Fauna Core HTTP API to:
- Run Fauna Query Language (FQL) queries
- Perform change data capture (CDC)
- Subscribe to real-time events
- Manage database schema
The Fauna client drivers, Fauna Dashboard, and Fauna CLI use the Core API to access data in Fauna databases.
Fauna Core API endpoints use https://db.fauna.com as the base URL.
For example, the full URL for the /query/1
(Query) endpoint is https://db.fauna.com/query/1
.
Fauna routes requests to a database based on the secret used for authentication. All requests and queries run in the context of a single database.
You authenticate requests to Fauna Core API endpoints using an authentication secret. You pass the authentication secret as a bearer token in the Authorization
request header.
Get an authentication secret
Fauna supports several secret types. For testing, you can create a key, which is a type of secret:
Log in to the Fauna Dashboard.
On the Explorer page, create a database.
In the database's Keys tab, click Create Key.
Choose a Role of server.
Click Save.
Copy the Key Secret. The secret is scoped to the database.
The Query endpoint lets you run Fauna Query Language (FQL) queries.
Query endpoint
Runs an FQL query against a specific database.
Every query is an independently authenticated request to the Query endpoint. The Fauna client drivers, Fauna Dashboard, and Fauna CLI use the Query endpoint to run queries.
In Fauna, every query is a transaction, run in the context of a single database. Fauna routes and authorizes queries using an authentication secret, scoped to a specific database. You pass the authentication secret as a bearer token in the Authorization
request header.
Data format
The Query endpoint's X-Format
request header specifies the data format used to encode FQL
values in:
- Query results.
- FQL query arguments passed in the
arguments
parameter or within objects passed to thequery
parameter. - Abort values returned by abort errors.
See the Wire protocol docs.
Error handling
Error responses from the Query API include error codes.
Fauna error codes are part of the API contract and are safe to write programmatic logic against. You should first handle errors based on error code, rather than HTTP status code.
See Error handling.
Authorizations:
header Parameters
Authorization required | string Example: Bearer <FAUNA_SECRET> A Fauna authentication secret, passed as a bearer token. See Authentication for more details. |
X-Format | string Data format used to encode FQL values as JSON (and the reverse) in:
Accepts For more information, see Wire Protocol. |
X-Last-Txn-Ts | integer If set, acts as the minimum snapshot time against which the query executes. Fauna's client drivers set this value as the last |
X-Linearized | boolean If true, strictly serializes read-only queries that don't involve indexes. Queries that include writes are already strictly serialized. |
X-Max-Contention-Retries | integer Maximum number of times to retry the query due to transaction contention. |
X-Performance-Hints | boolean If true, query responses include performance
hints,
if applicable, in the |
X-Query-Tags | string A string-encoded set of query tags. Query tags let you instrument queries to better identify their source
and context in Fauna
Logs. Query
tags are returned in the response's You provide query tags as a list of
Keys and values may only support
Queries that include invalid tags return an A query can't include more than 25 query tags. Each key must be less than or equal to 40 bytes. Each value must be less than or equal to 80 bytes. The full header can't exceed 3000 bytes. |
X-Query-Timeout-Ms | integer Maximum runtime for the request in milliseconds. |
X-Typecheck | boolean Enable or disable typechecking for the query. Defaults to the typechecking configuration for the database. |
Request Body schema: application/jsonrequired
required | object or string FQL query to run. Accepts an object or a string. Use |
arguments | object Object containing variables to interpolate into the The key of each object property is the name of the variable,
referenced in the Variable names must be valid FQL identifiers. Variable values should
be encoded using the data
format
specified in the |
Responses
Request samples
- Payload
- curl - Simple query
- curl - Query object
- curl - Query string
{- "query": {
- "fql": [
- "Product.all().where(.stock ==",
- {
- "value": {
- "@int": "10"
}
}, - ")"
]
}
}
Response samples
- 200
- 400
- 401
- 409
- 429
- 440
- 500
- 502
- 503
- 504
{- "data": {
- "data": {
- "id": "410212968961146957",
- "coll": {
- "@mod": "Product"
}, - "ts": {
- "@time": "2099-07-29T14:26:37.650Z"
}, - "name": "cups",
- "description": "Translucent 9 Oz, 100 ct",
- "price": {
- "@int": 698
}, - "stock": {
- "@int": 100
}, - "category": {
- "@ref": {
- "id": "410212968956952653",
- "coll": {
- "@mod": "Category"
}
}
}
}
}, - "static_type": "Set<Product>",
- "summary": "",
- "txn_ts": 1727892962009660,
- "stats": {
- "compute_ops": 1,
- "read_ops": 18,
- "write_ops": 0,
- "query_time_ms": 215,
- "contention_retries": 0,
- "storage_bytes_read": 2158,
- "storage_bytes_write": 0,
- "rate_limits_hit": [ ]
}, - "schema_version": 1727880352326000
}
Event endpoints lets you consume events from an event source. An event source emits an event whenever tracked changes are made to a database.
You can consume the events in two ways:
Event Feeds: Make asynchronous requests that poll the event source for paginated events using the Event Feed endpoint.
Event Streams: Establish a real-time subscription that pushes events to your application through an open connection to the Event Stream endpoint.
Event Feed endpoint
To use the Event Feed endpoint, you must have a Pro or Enterprise plan.
Asynchronously gets events from an event source as a paginated Event Feed.
Authorizations:
header Parameters
Authorization required | string Example: Bearer <FAUNA_SECRET> A Fauna authentication secret, passed as a bearer token. See Authentication for more details. |
X-Query-Timeout-Ms | integer Maximum runtime for the request in milliseconds. |
Request Body schema: application/jsonrequired
token required | string The event source token determines:
|
cursor | string Cursor for a previous event. If provided, the event source replays any events that occurred after the cursor (exclusive). You can reuse cursors across event sources with identical queries in the same database. You can't pass both If you don't provide a |
start_ts | integer Stream start time in microseconds since the Unix epoch.
This is typically a previous event's You can't pass both If you don't provide a If |
page_size | integer Maximum number of events returned per page. Must be in the range 1 to 16000 (inclusive). Defaults to 16. |
Responses
Request samples
- Payload
- curl
{- "token": "<EVENT_SOURCE>",
- "cursor": "gsGabc123",
- "start_ts": 1710968002310000,
- "page_size": 10
}
Response samples
- 200
- 400
- 401
{- "events": [
- {
- "type": "update",
- "data": {
- "@doc": {
- "id": "412095363338469409",
- "coll": {
- "@mod": "Product"
}, - "ts": {
- "@time": "2099-10-18T21:54:07.340Z"
}, - "name": "cups",
- "description": "Translucent 9 Oz, 100 ct",
- "price": {
- "@int": "698"
}, - "stock": {
- "@int": "99"
}, - "category": {
- "@ref": {
- "id": "412095363334275105",
- "coll": {
- "@mod": "Category"
}
}
}
}
}, - "txn_ts": 1729288447340000,
- "cursor": "gsGCGmcS2P8aFEP9AAA=",
- "stats": {
- "read_ops": 1,
- "storage_bytes_read": 171,
- "compute_ops": 1,
- "processing_time_ms": 3,
- "rate_limits_hit": [ ]
}
}
], - "cursor": "gsGCGmcS2P8aFEP9AAA=",
- "has_next": false,
- "stats": {
- "read_ops": 9,
- "storage_bytes_read": 481,
- "compute_ops": 1,
- "processing_time_ms": 7,
- "rate_limits_hit": [ ]
}
}
Event Stream endpoint
Subscribe to real-time events from an event source. See Event Streams.
The Event Stream endpoint maintains an open connection and pushes events to the client as they occur.
Authorizations:
header Parameters
Authorization required | string Example: Bearer <FAUNA_SECRET> A Fauna authentication secret, passed as a bearer token. See Authentication for more details. |
X-Query-Timeout-Ms | integer Maximum runtime for the request in milliseconds. |
Request Body schema: application/jsonrequired
token required | string The event source token determines:
|
cursor | string Cursor for a previous event. If provided, the event source replays any events that occurred after the cursor (exclusive). You can reuse cursors across event sources with identical queries in the same database. You can't pass both If you don't provide a |
start_ts | integer Stream start time in microseconds since the Unix epoch.
This is typically a previous event's You can't pass both If you don't provide a For Event Streams, If |
Responses
Request samples
- Payload
- curl
{- "token": "<EVENT_SOURCE>",
- "cursor": "gsGabc123",
- "start_ts": 1710968002310000
}
Response samples
- 200
- 400
- 401
{- "type": "update",
- "data": {
- "@doc": {
- "id": "412095363338469409",
- "coll": {
- "@mod": "Product"
}, - "ts": {
- "@time": "2099-10-18T22:12:58.440Z"
}, - "name": "cups",
- "description": "Translucent 9 Oz, 100 ct",
- "price": {
- "@int": "698"
}, - "stock": {
- "@int": "100"
}, - "category": {
- "@ref": {
- "id": "412095363334275105",
- "coll": {
- "@mod": "Category"
}
}
}
}
}, - "txn_ts": 1729289578440000,
- "cursor": "gsGCGmcS3WoaGjneAAA=",
- "stats": {
- "read_ops": 1,
- "storage_bytes_read": 320,
- "compute_ops": 1,
- "processing_time_ms": 0,
- "rate_limits_hit": [ ]
}
}
Schema endpoints let you fetch, update, and manage a database's schema as .fsl
schema files.
Internally, the Fauna CLI uses these endpoints to execute fauna schema
commands.
Abandon staged schema endpoint
Abandons the database's current staged schema.
You can abandon a staged schema at any time, including a schema with the ready
status. This is useful when you want to discard changes that are no longer needed or failed during staging.
If the database has no staged schema, requests to the endpoint return an error with a 400
HTTP status code.
Requests to this endpoint must use an authentication secret with the built-in admin
role.
Authorizations:
query Parameters
version | integer <int64> Database schema version used for optimistic concurrency control. If the active schema version is not equal to this value, the request returns an error with a 409 HTTP status code. |
header Parameters
Authorization required | string Example: Bearer <FAUNA_SECRET> A Fauna authentication secret, passed as a bearer token. See Authentication for more details. |
Responses
Request samples
- curl
curl -X POST "https://db.fauna.com/schema/1/staged/abandon" \ -H "Authorization: Bearer <FAUNA_SECRET>"
Response samples
- 200
- 400
- 401
- 403
- 405
- 409
- 500
- 503
{- "version": 1234567890123456
}
Commit staged schema endpoint
Commits a staged schema change to the database. When committed, the database's staged schema becomes its active schema.
You can only commit a staged schema that has a status of ready
. You can check the status using the Get staged schema status endpoint.
If the staged schema status is not ready
or the database has no staged schema, requests to the endpoint return an error with a 400
HTTP status code.
Requests to this endpoint must use an authentication secret with the built-in admin
role.
Authorizations:
query Parameters
version | integer <int64> Database schema version used for optimistic concurrency control. If the active schema version is not equal to this value, the request returns an error with a 409 HTTP status code. |
header Parameters
Authorization required | string Example: Bearer <FAUNA_SECRET> A Fauna authentication secret, passed as a bearer token. See Authentication for more details. |
Responses
Request samples
- curl
curl -X POST "https://db.fauna.com/schema/1/staged/commit" \ -H "Authorization: Bearer <FAUNA_SECRET>"
Response samples
- 200
- 400
- 401
- 403
- 405
- 409
- 500
- 503
{- "version": 1234567890123456
}
Diff schema files endpoint
Validates provided .fsl
schema files. Returns the diff between provided schema and the staged or active schema.
Requests to this endpoint must use an authentication secret with the built-in admin
, server
, or server-readonly
role.
Authorizations:
query Parameters
color | string Type of escape codes used to format the response's |
format | string Type of diff returned in the output. Accepts one of the following:
|
staged | boolean If Defaults to |
version | integer <int64> Database schema version used for optimistic concurrency control. If the active schema version is not equal to this value, the request returns an error with a 409 HTTP status code. |
header Parameters
Authorization required | string Example: Bearer <FAUNA_SECRET> A Fauna authentication secret, passed as a bearer token. See Authentication for more details. |
Request Body schema: multipart/form-datarequired
.fsl
schema files to validate.
Each form-data field corresponds to the file's name, including any relative path for subdirectories within the schema directory. The field's value is the file's content, provided as an .fsl
file.
Example curl usage:
-F "collections.fsl=@./schema/collections.fsl"
Filenames must end in .fsl
and can't start with *
. Requests with an invalid filename return an error with a 400 HTTP status code.
property name* additional property | string <binary> |
Responses
Request samples
- Payload
- curl
{ "collections.fsl": "./schema/collections.fsl", "fn/functions.fsl": "./schema/fn/functions.fsl" }
Response samples
- 200
- 400
- 401
- 403
- 405
- 409
- 500
- 503
{- "version": 1234567890123456,
- "diff": "* Modifying collection `Customer` at collections.fsl:2:1:\n * Indexes:\n + add index `byName`\n\n"
}
Get schema filenames endpoint
Fetches a database's remote .fsl
schema filenames.
When you push .fsl
files to Fauna, Fauna retains the filenames and directory organization. This lets you later pull the same files.
Schema created using FQL schema methods are stored in the main.fsl
file.
Requests to this endpoint must use an authentication secret with the built-in admin
, server
, or server-readonly
role.
Authorizations:
query Parameters
staged | boolean If Defaults to |
version | integer <int64> Database schema version used for optimistic concurrency control. If the active schema version is not equal to this value, the request returns an error with a 409 HTTP status code. |
header Parameters
Authorization required | string Example: Bearer <FAUNA_SECRET> A Fauna authentication secret, passed as a bearer token. See Authentication for more details. |
Responses
Request samples
- curl
curl -G \ 'https://db.fauna.com/schema/1/files' \ -H 'Authorization: Bearer <FAUNA_SECRET>' \ -d "staged=true" \ -d "version=12345"
Response samples
- 200
- 400
- 401
- 403
- 405
- 409
- 500
- 503
{- "version": 1234567890123456,
- "files": [
- {
- "filename": "collections.fsl"
}, - {
- "filename": "fn/functions.fsl"
}
]
}
Get schema file endpoint
Fetches the content of a remote .fsl
schema file from Fauna.
To fetch a schema file, you must specify a valid .fsl
filename for the database. You can get a list of valid filenames from the Get schema filenames endpoint.
Requests to this endpoint must use an authentication secret with the built-in admin
, server
, or server-readonly
role.
Authorizations:
path Parameters
filename required | string URL-escaped filename for |
query Parameters
staged | boolean If Defaults to |
version | integer <int64> Database schema version used for optimistic concurrency control. If the active schema version is not equal to this value, the request returns an error with a 409 HTTP status code. |
header Parameters
Authorization required | string Example: Bearer <FAUNA_SECRET> A Fauna authentication secret, passed as a bearer token. See Authentication for more details. |
Responses
Request samples
- curl
curl -G \ 'https://db.fauna.com/schema/1/files/collections.fsl' \ -H 'Authorization: Bearer <FAUNA_SECRET>' \ -d "staged=true" \ -d "version=12345"
Response samples
- 200
- 400
- 401
- 403
- 404
- 405
- 409
- 500
- 503
{- "version": 1234567890123456,
- "content": "collection Product {\n}\n"
}
Get staged schema status endpoint
Gets the index build status for the database's current staged schema.
If format
is specified, the request also returns a diff between the staged and active schema.
Requests to this endpoint must use an authentication secret with the built-in admin
, server
, or server-readonly
role.
Authorizations:
query Parameters
color | string Type of escape codes used to format the following response properties in color:
Accepts |
format | string Type of diff returned in the output. Accepts one of the following:
|
version | integer <int64> Database schema version used for optimistic concurrency control. If the active schema version is not equal to this value, the request returns an error with a 409 HTTP status code. |
header Parameters
Authorization required | string Example: Bearer <FAUNA_SECRET> A Fauna authentication secret, passed as a bearer token. See Authentication for more details. |
Responses
Request samples
- curl
curl -G \ 'https://db.fauna.com/schema/1/staged/status' \ -H 'Authorization: Bearer <FAUNA_SECRET>' \ -d "version=12345" \ -d "format=semantic"
Response samples
- 200
- 400
- 401
- 403
- 405
- 409
- 500
- 503
{- "version": 1234567890123456,
- "status": "ready"
}
Update schema files endpoint
Performs a schema change by uploading .fsl
schema files to Fauna.
The request replaces the entire staged or active database schema. Only schema in the request are retained. Schema not present in the request are deleted, along with their related resources.
Requests to this endpoint must use an authentication secret with the built-in admin
role.
Authorizations:
query Parameters
staged | boolean If Defaults to |
version | integer <int64> Database schema version used for optimistic concurrency control. If the active schema version is not equal to this value, the request returns an error with a 409 HTTP status code. |
header Parameters
Authorization required | string Example: Bearer <FAUNA_SECRET> A Fauna authentication secret, passed as a bearer token. See Authentication for more details. |
Request Body schema: multipart/form-datarequired
.fsl
schema files to upload.
Each form-data field corresponds to the file's name, including any relative
path for subdirectories within the schema directory. The field's value is the
file's content, provided as an .fsl
file.
Example curl usage:
-F "collections.fsl=@./schema/collections.fsl"
Filenames must end in .fsl
and can't start with *
. Requests with
an invalid filename return an error with a 400 HTTP status code.
property name* additional property | string <binary> |
Responses
Request samples
- Payload
- curl
{ "collections.fsl": "./schema/collections.fsl", "fn/functions.fsl": "./schema/fn/functions.fsl" }
Response samples
- 200
- 400
- 401
- 403
- 405
- 409
- 500
- 503
{- "version": 1234567890123456
}
Is this article helpful?
Tell Fauna how the article can be improved:
Visit Fauna's forums
or email docs@fauna.com
Thank you for your feedback!