2026-03-01 03:04:24 +08:00
|
|
|
import { NextRequest, NextResponse } from 'next/server';
|
|
|
|
|
import { z } from 'zod';
|
2026-03-07 04:15:54 +08:00
|
|
|
import { cancelOrder } from '@/lib/order/service';
|
2026-03-01 19:25:14 +08:00
|
|
|
import { getCurrentUserByToken } from '@/lib/sub2api/client';
|
2026-03-07 04:15:54 +08:00
|
|
|
import { handleApiError } from '@/lib/utils/api';
|
2026-03-01 03:04:24 +08:00
|
|
|
|
|
|
|
|
const cancelSchema = z.object({
|
2026-03-01 19:25:14 +08:00
|
|
|
token: z.string().min(1),
|
2026-03-01 03:04:24 +08:00
|
|
|
});
|
|
|
|
|
|
2026-03-01 17:58:08 +08:00
|
|
|
export async function POST(request: NextRequest, { params }: { params: Promise<{ id: string }> }) {
|
2026-03-01 03:04:24 +08:00
|
|
|
try {
|
|
|
|
|
const { id } = await params;
|
|
|
|
|
const body = await request.json();
|
|
|
|
|
const parsed = cancelSchema.safeParse(body);
|
|
|
|
|
|
|
|
|
|
if (!parsed.success) {
|
2026-03-01 19:25:14 +08:00
|
|
|
return NextResponse.json({ error: '缺少 token 参数' }, { status: 400 });
|
2026-03-01 03:04:24 +08:00
|
|
|
}
|
|
|
|
|
|
2026-03-01 19:25:14 +08:00
|
|
|
let userId: number;
|
|
|
|
|
try {
|
|
|
|
|
const user = await getCurrentUserByToken(parsed.data.token);
|
|
|
|
|
userId = user.id;
|
|
|
|
|
} catch {
|
|
|
|
|
return NextResponse.json({ error: '登录态已失效,无法取消订单' }, { status: 401 });
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const outcome = await cancelOrder(id, userId);
|
2026-03-01 18:44:49 +08:00
|
|
|
if (outcome === 'already_paid') {
|
|
|
|
|
return NextResponse.json({ success: true, status: 'PAID', message: '订单已支付完成' });
|
|
|
|
|
}
|
2026-03-01 03:04:24 +08:00
|
|
|
return NextResponse.json({ success: true });
|
|
|
|
|
} catch (error) {
|
2026-03-07 04:15:54 +08:00
|
|
|
return handleApiError(error, '取消订单失败');
|
2026-03-01 03:04:24 +08:00
|
|
|
}
|
|
|
|
|
}
|