我尝试将NextAuth Credentials与Typescript一起使用,但它总是显示这样的类型错误,我只是从文档中复制了示例,但无法正确运行它:下面是/pages/auth/[...nextauth].ts
中的代码
return await NextAuth(req, res, {
providers: [
CredentialsProvider({
name: 'Credentials',
credentials: {
email: { label: 'Email', type: 'email' },
password: { label: 'Password', type: 'password' },
},
async authorize(credentials, req) {
const { email, password } = credentials as { email: string; password: string; };
const { user } = await loginUser({ email, password });
if (!user) {
return null;
}
return user;
},
}),
],
callbacks: {
session({ session, token, user }) {
return session;
},
async jwt({ token }) {
return token;
},
},
adapter: PrismaAdapter(prisma),
});
authorize
函数总是显示以下类型检查错误:
Type '(credentials: Record<"email" | "password", string> | undefined, res: Pick<RequestInternal, "query" | "body" | "headers" | "method">) => Promise<...>' is not assignable to type '(credentials: Record<"email" | "password", string> | undefined, req: Pick<RequestInternal, "query" | "body" | "headers" | "method">) => Awaitable<...>'.
Type 'Promise<User | null>' is not assignable to type 'Awaitable<User | null>'.
Type 'Promise<User | null>' is not assignable to type 'PromiseLike<User | null>'.
Types of property 'then' are incompatible.
Type '<TResult1 = User | null, TResult2 = never>(onfulfilled?: ((value: User | null) => TResult1 | PromiseLike<TResult1>) | null | undefined, onrejected?: ((reason: any) => TResult2 | PromiseLike<...>) | null | undefined) => Promise<...>' is not assignable to type '<TResult1 = User | null, TResult2 = never>(onfulfilled?: ((value: User | null) => TResult1 | PromiseLike<TResult1>) | null | undefined, onrejected?: ((reason: any) => TResult2 | PromiseLike<...>) | null | undefined) => PromiseLike<...>'.
Types of parameters 'onfulfilled' and 'onfulfilled' are incompatible.
Types of parameters 'value' and 'value' are incompatible.
Type 'import("/app/node_modules/.prisma/client/index").User | null' is not assignable to type 'import("/app/node_modules/next-auth/core/types").User | null'.
Type 'import("/app/node_modules/.prisma/client/index").User' is not assignable to type 'import("/app/node_modules/next-auth/core/types").User'.
Types of property 'id' are incompatible.
Type 'number' is not assignable to type 'string'.ts(2322)
credentials.d.ts(13, 5): The expected type comes from property 'authorize' which is declared here on type 'UserCredentialsConfig<{ email: { label: string; type: string; }; password: { label: string; type: string; }; }>'
我将此类型定义添加到types/next-auth.d.ts
import 'next-auth';
import { User as UserModel } from '@prisma/client';
declare module 'next-auth' {
interface User extends UserModel {}
interface Session {
user: User;
expires: string;
}
}
但错误仍然存在
下面是loginUser
函数
import { compare } from 'bcryptjs';
import prisma from '@/libs/prisma';
import { User } from '@prisma/client';
import { UserLoginData } from '@/types/auth';
export const LoginUser = async ({
email,
password,
}: UserLoginData): Promise<{
user: User | null;
error: Error | null;
}> => {
const user = await prisma.user.findUnique({ where: { email } });
if (!user) {
return {
user: null,
error: new Error(`User with email: ${email} does not exist.`),
};
}
const isValid = password && user.password && (await compare(password, user.password));
if (!isValid) {
return {
user,
error: new Error('Invalid password.'),
};
}
return { user, error: null };
};
1条答案
按热度按时间nkoocmlb1#
我之所以能理解它,是因为在我的Prisma模式中,我用类型
number
声明了id
字段,而“next-auth”中的id
字段是string
,因此我需要从核心扩展接口,并将id
定义添加为number
,以匹配我的Prisma模式,现在它可以工作了!