Overview
TypeORM Adapter​
NextAuth.js comes with a default Adapter that uses TypeORM so that it can be used with many different databases without any further configuration, you simply add the node module for the database driver you want to use in your project and pass a database connection string to NextAuth.js.
Database Schemas​
Configure your database by creating the tables and columns to match the schema expected by NextAuth.js.
The default Adapter is the TypeORM Adapter and the default database type for TypeORM is SQLite, the following configuration options are exactly equivalent.
database: {
type: 'sqlite',
database: ':memory:',
synchronize: true
}
adapter: Adapters.Default({
type: "sqlite",
database: ":memory:",
synchronize: true,
})
adapter: Adapters.TypeORM.Adapter({
type: "sqlite",
database: ":memory:",
synchronize: true,
})
The tutorial Custom models with TypeORM explains how to extend the built in models and schemas used by the TypeORM Adapter. You can use these models in your own code.
The synchronize
option in TypeORM will generate SQL that exactly matches the documented schemas for MySQL and Postgres. This will automatically apply any changes it finds in the entity model, therefore it should not be enabled against production databases as it may cause data loss if the configured schema does not match the expected schema!