Supabase generates APIs directly from your Database schema. The API is:
- Instant and auto-generated: as you update your database the changes are immediately accessible through your API.
- Self documenting: Supabase generates documentation in the Dashboard which updates as you make database changes.
- Secure: the API is configured to work with PostgreSQL's Row Level Security, provisioned behind an API gateway with key-auth enabled.
- Fast: our benchmarks for basic reads are more than 300% faster than Firebase. The API is a very thin layer on top of Postgres, which does most of the heavy-lifting.
- Scalable: the API can serve thousands of simultaneous requests, and works well for Serverless workloads.
Supabase provides a RESTful API using PostgREST. This is a very thin API layer on top of Postgres. It provides everything you need from a CRUD API:
- Basic CRUD operations
- Deeply nested joins, allowing you to fetch data from multiple tables in a single fetch
- Works with Postgres Views
- Works with Postgres Functions
- Works with the Postgres security model - including Row Level Security, Roles, and Grants.
Supabase provides a Realtime API using Realtime. You can use this to listen to database changes over websockets. Realtime leverages PostgreSQL's built-in logical replication. You can manage your Realtime API simply by managing Postgres publications.
After you have added tables or functions to your database, you can use the API.
API routes are automatically created when you create Postgres Tables, Views, or Functions.
Let's create our first
API route by creating a table called
todos (which will store some public user information).
This will create a corresponding route
todos which can accept
Every Supabase project has a unique API URL. Your API is secured behind an API gateway which requires an API Key for every request.
You can find the Keys inside the Dashboard.
You are provided with two keys initially:
anonkey, which is safe to be used in a browser context.
service_rolekey, which should only be used on a server. This key can bypass Row Level Security.
Supabase generates documentation in the Dashboard which updates as you make database changes.
Let's view the documentation for the
todos table which we created in the first step.
You can interact with your API directly via HTTP requests, or you can use the client libraries which we provide.
Let's see how to make a request to the
todos table which we created in the first step,
using the API URL (
[SUPABASE_URL]) and Key (
[SUPABASE_ANON_KEY]) we provided:
- When you create a table in Postgres, Row Level Security is disabled by default. Make sure you secure it by enabling RLS.
- Never expose the
service_rolekey in a browser or anywhere where a user can see it.
- JS Reference: select(), insert(), update(), upsert(), delete(), rpc() (call Postgres functions).
The Realtime API works through PostgreSQL's replication functionality. Postgres sends database changes to a "publication"
supabase_realtime, and by managing this publication you can control which data is broadcast.
By default Realtime is disabled on your database. Let's turn on Realtime for the
- You should only turn on realtime for Public tables (where all data should be accessible).
- JS Reference: Subscribe to database changes using the realtime client