Files
konstitisyon.nu/app/api/auth/[...nextauth]/options.js
T

76 lines
1.8 KiB
JavaScript
Raw Normal View History

2024-05-20 04:14:16 +04:00
import CredentialsProvider from 'next-auth/providers/credentials'
import {readMe, withToken} from '@directus/sdk'
import {directusClient} from '@/lib/directus.js'
const apiUrl = process.env.DIRECTUS_API_URL
const nextauthSecret = process.env.NEXTAUTH_SECRET
export const options = {
providers: [
CredentialsProvider({ // eslint-disable-line new-cap
name: 'Credentials',
credentials: {
email: {},
password: {}
},
async authorize(credentials) {
const res = await fetch(`${apiUrl}/auth/login`, {
method: 'POST',
body: JSON.stringify(credentials),
headers: {'Content-Type': 'application/json'}
})
const user = await res.json()
if (res.ok && user) {
return user
}
return null
}
})
],
2024-06-21 09:57:05 +04:00
trustHost: true,
2024-05-20 04:14:16 +04:00
secret: nextauthSecret,
pages: {
signIn: '/login'
},
callbacks: {
async jwt({
token,
user,
account
}) {
if (account && user) {
const userData = await directusClient.request(
withToken(
user.data.access_token,
readMe({
2024-05-23 18:43:53 +04:00
fields: ['*']
2024-05-20 04:14:16 +04:00
})
)
)
2024-05-23 18:43:53 +04:00
2024-05-20 04:14:16 +04:00
return {
...token,
accessToken: user.data.access_token,
refreshToken: user.data.refresh_token,
user: userData
}
}
return token
},
async session({session, token}) {
2024-05-23 18:43:53 +04:00
session.user.userId = token.user.id
session.user.username = token.user.first_name
session.user.accessToken = token.accessToken
session.user.refreshToken = token.refreshToken
session.user.token = token.user.token
session.user.email = token.user.email
session.user.password = token.user.password
2024-05-20 04:14:16 +04:00
return session
}
}
}