跳至內容
從 NextAuth.js v4 遷移?請閱讀 我們的遷移指南.

Upstash Redis 轉接器

資源

設定

安裝

npm install @upstash/redis @auth/upstash-redis-adapter

環境變數

UPSTASH_REDIS_URL,
UPSTASH_REDIS_TOKEN

組態

./auth.ts
import NextAuth from "next-auth"
import { UpstashRedisAdapter } from "@auth/upstash-redis-adapter"
import { Redis } from "@upstash/redis"
 
const redis = new Redis({
  url: process.env.UPSTASH_REDIS_URL!,
  token: process.env.UPSTASH_REDIS_TOKEN!,
})
 
export const { handlers, auth, signIn, signOut } = NextAuth({
  adapter: UpstashRedisAdapter(redis),
  providers: [],
})

進階用法

使用單一 Upstash Redis 執行個體搭配多個應用程式

Upstash 免費方案只允許一個 Redis 執行個體。如果您有多個 Auth.js 連線應用程式使用此執行個體,則每個應用程式需要不同的金鑰前綴。

您可以將 options 物件作為轉接器工廠函式的第二個引數來變更前綴。

此物件的預設值為

const defaultOptions = {
  baseKeyPrefix: "",
  accountKeyPrefix: "user:account:",
  accountByUserIdPrefix: "user:account:by-user-id:",
  emailKeyPrefix: "user:email:",
  sessionKeyPrefix: "user:session:",
  sessionByUserIdKeyPrefix: "user:session:by-user-id:",
  userKeyPrefix: "user:",
  verificationTokenKeyPrefix: "user:token:",
}

通常,變更 baseKeyPrefix 應該足以應付此情境,但對於更多自訂設定,您也可以變更每個金鑰的前綴。

export const { handlers, auth, signIn, signOut } = NextAuth({
  adapter: UpstashRedisAdapter(redis, { baseKeyPrefix: "app2:" }),
})
Auth.js © Balázs Orbán 和團隊 -2024