This document describes the high-level architecture of PostgREST.
postgrest :: Request -> Either Error SQLStatement -> Response
On the highest level, PostgREST processes an HTTP request, if it's accepted it builds a SQL statement for it, executes it, and produces a response.
This section talks briefly about various important modules.
The starting point of the program is main/Main.hs
, which calls src/PostgREST/CLI.hs
which then calls src/PostgREST/App.hs
.
App.hs
is then in charge of composing the different modules.
PostgREST operates over two types of resources: database relations(tables or views) and database functions; providing different representations(depending on the media type) for them.
This module is in charge of representing the operation over an ApiRequest
type. It parses the URL querystring following PostgREST syntax, the request headers, and the request body
(if possible it avoids parsing the body and sends it directly to the db).
A request might be rejected at this level if it's invalid, e.g. providing an unknown media type to PostgREST or using an unknown HTTP method.
Using the Schema Cache, this module enables more complex functionality(like resource embedding) by enriching the ApiRequest. It generates Plan types(ReadPlan
, MutatePlan
)
that then will be used to generate a SQL statement.
A request might be rejected at this level if it's invalid, e.g. by doing resource embedding on a nonexistent resource.
An OPTIONS request doesn't require a plan to be generated.
This module constructs single SQL statements that can be parametrized and prepared. Only at this stage a PostgreSQL connection from the pool is used.
A query might fail(and be rollbacked) at this level if it doesn't comply to certain conditions, e.g. by not returning a single row when a Accept: application/vnd.pgrst.object
header is specified.
An OPTIONS request doesn't require a query to be executed.
This module constructs the HTTP response body with the right headers.
It builds the OpenAPI response using the schema cache.
This module provides functions to deal with JWT authorization.
This queries the PostgreSQL system catalogs and caches the metadata into a SchemaCache type,
The state of the App which is kept across requests.
This spawns threads which are used to execute concurrent jobs.
Jobs include connection recover and a listener for the PostgreSQL LISTEN command.