Authentication Setup
PowerSync clients (i.e. apps used by your users that embed the PowerSync Client SDK) authenticate against the server-side PowerSync Service using JWTs (signed tokens) that are generated by your application backend.
Before using PowerSync, an application’s existing architecture may look like this:
data:image/s3,"s3://crabby-images/8a5a9/8a5a9d156510e4ba8f8b571515e2ef5833aaf1cc" alt="".png)
The PowerSync Service uses database native credentials and authenticates directly against the backend database using the configured credentials:
data:image/s3,"s3://crabby-images/99eeb/99eeb41816239bfc1587455691ed0b57508741c8" alt="".png)
When the PowerSync client SDK is included in an app project, it uses existing app-to-backend authentication to retrieve a JSON Web Token (JWT):
data:image/s3,"s3://crabby-images/80b04/80b04f359017012edabaab79741bb86cae94b33f" alt="".png)
The PowerSync client SDK uses the retrieved JWT to authenticate directly against the PowerSync Service:
data:image/s3,"s3://crabby-images/dc06b/dc06bf94e1fd3761c51c61a7c5e7abd313ba3051" alt="".png)
Users are not persisted in PowerSync, and there is no server-to-server communication used for client authentication.
Some authentication providers already generate JWTs for users which PowerSync can verify directly — see the documentation for individual providers (e.g. Supabase Auth, Firebase Auth)
For others, some backend code must be added to your application backend to generate the JWTs needed for PowerSync — see Custom authentication.
For a quick way to get up and running during development, you can generate Development Tokens directly from the PowerSync Dashboard (PowerSync Cloud) or locally with a self-hosted setup.
Was this page helpful?