MikroORM 配接器
資源
設定
安裝
npm install @mikro-orm/core @auth/mikro-orm-adapter
環境變數
DATABASE_CONNECTION_STRING=./db.sqlite
組態
./auth.ts
import NextAuth from "next-auth"
import { MikroOrmAdapter } from "@auth/mikro-orm-adapter"
export const { handlers, auth, signIn, signOut } = NextAuth({
adapter: MikroOrmAdapter({
// MikroORM options object - https://mikro-orm.io/docs/next/configuration#driver
dbName: process.env.DATABASE_CONNECTION_STRING,
type: "sqlite",
debug: true,
}),
providers: [],
})
進階用法
傳遞自訂實體
MikroORM 配接器隨附其自身的一組實體。如果您想要擴充它們,您可以選擇性地將它們傳遞給配接器。
此結構描述適用於 MikroORM,並基於我們的主要結構描述
./auth.ts
import config from "config/mikro-orm.ts"
import {
Cascade,
Collection,
Entity,
OneToMany,
PrimaryKey,
Property,
Unique,
} from "@mikro-orm/core"
import { defaultEntities } from "@auth/mikro-orm-adapter"
const type { Account, Session } = defaultEntities
@Entity()
export class User implements defaultEntities.User {
@PrimaryKey()
id: string = randomUUID()
@Property({ nullable: true })
name?: string
@Property({ nullable: true })
@Unique()
email?: string
@Property({ type: "Date", nullable: true })
emailVerified: Date | null = null
@Property({ nullable: true })
image?: string
@OneToMany({
entity: () => Session,
mappedBy: (session) => session.user,
hidden: true,
orphanRemoval: true,
cascade: [Cascade.ALL],
})
sessions = new Collection<Session>(this)
@OneToMany({
entity: () => Account,
mappedBy: (account) => account.user,
hidden: true,
orphanRemoval: true,
cascade: [Cascade.ALL],
})
accounts = new Collection<Account>(this)
@Enum({ hidden: true })
role = "ADMIN"
}
export const { handlers, auth, signIn, signOut } = NextAuth({
adapter: MikroOrmAdapter(config, { entities: { User } }),
})
包含預設實體
您可能想要在 MikroORM 組態中包含 defaultEntities,以將它們包含在移轉等中。
若要實現此目的,請將它們包含在您的「entities」陣列中
config/mikro-orm.ts
import { Options } from "@mikro-orm/core"
import { defaultEntities } from "@auth/mikro-orm-adapter"
const config: Options = {
entities: [VeryImportantEntity, ...Object.values(defaultEntities)],
}
export default config