mirror of
https://github.com/labring/FastGPT.git
synced 2025-07-23 05:12:39 +00:00
52 lines
1.3 KiB
TypeScript
52 lines
1.3 KiB
TypeScript
// Next.js API route support: https://nextjs.org/docs/api-routes/introduction
|
|
import type { NextApiRequest, NextApiResponse } from 'next';
|
|
import { jsonRes } from '@/service/response';
|
|
import { connectToDatabase, Bill } from '@/service/mongo';
|
|
import { authToken } from '@/service/utils/tools';
|
|
import type { BillSchema } from '@/types/mongoSchema';
|
|
|
|
export default async function handler(req: NextApiRequest, res: NextApiResponse) {
|
|
try {
|
|
const { authorization } = req.headers;
|
|
let { pageNum = 1, pageSize = 10 } = req.query as { pageNum: string; pageSize: string };
|
|
|
|
pageNum = +pageNum;
|
|
pageSize = +pageSize;
|
|
|
|
if (!authorization) {
|
|
throw new Error('缺少登录凭证');
|
|
}
|
|
|
|
const userId = await authToken(authorization);
|
|
|
|
await connectToDatabase();
|
|
|
|
// 根据 id 获取用户账单
|
|
const bills = await Bill.find<BillSchema>({
|
|
userId
|
|
})
|
|
.sort({ _id: -1 }) // 按照创建时间倒序排列
|
|
.skip((pageNum - 1) * pageSize)
|
|
.limit(pageSize);
|
|
|
|
// 获取total
|
|
const total = await Bill.countDocuments({
|
|
userId
|
|
});
|
|
|
|
jsonRes(res, {
|
|
data: {
|
|
pageNum,
|
|
pageSize,
|
|
data: bills,
|
|
total
|
|
}
|
|
});
|
|
} catch (err) {
|
|
jsonRes(res, {
|
|
code: 500,
|
|
error: err
|
|
});
|
|
}
|
|
}
|