Files
sub2apipay/src/app/api/orders/[id]/route.ts

52 lines
1.6 KiB
TypeScript
Raw Normal View History

import { NextRequest, NextResponse } from 'next/server';
import { prisma } from '@/lib/db';
2026-03-10 11:52:37 +08:00
import { verifyAdminToken } from '@/lib/admin-auth';
import { deriveOrderState } from '@/lib/order/status';
import { ORDER_STATUS_ACCESS_QUERY_KEY, verifyOrderStatusAccessToken } from '@/lib/order/status-access';
/**
2026-03-10 11:52:37 +08:00
*
*
2026-03-10 11:52:37 +08:00
*
* - status / expiresAt
* - paymentSuccess
* - / rechargeSuccess / rechargeStatus
*/
export async function GET(request: NextRequest, { params }: { params: Promise<{ id: string }> }) {
const { id } = await params;
2026-03-10 11:52:37 +08:00
const accessToken = request.nextUrl.searchParams.get(ORDER_STATUS_ACCESS_QUERY_KEY);
const isAuthorized = verifyOrderStatusAccessToken(id, accessToken) || (await verifyAdminToken(request));
if (!isAuthorized) {
return NextResponse.json({ error: '未授权访问该订单状态' }, { status: 401 });
}
const order = await prisma.order.findUnique({
where: { id },
select: {
id: true,
status: true,
expiresAt: true,
2026-03-10 11:52:37 +08:00
paidAt: true,
completedAt: true,
failedReason: true,
},
});
if (!order) {
return NextResponse.json({ error: '订单不存在' }, { status: 404 });
}
2026-03-10 11:52:37 +08:00
const derived = deriveOrderState(order);
return NextResponse.json({
id: order.id,
status: order.status,
expiresAt: order.expiresAt,
2026-03-10 11:52:37 +08:00
paymentSuccess: derived.paymentSuccess,
rechargeSuccess: derived.rechargeSuccess,
rechargeStatus: derived.rechargeStatus,
failedReason: order.failedReason ?? null,
});
}