- Add Stripe payment provider with Checkout Session flow - Payment provider abstraction layer (EasyPay + Stripe unified interface) - Stripe webhook with proper raw body handling and signature verification - Frontend: Stripe button with URL validation, anti-duplicate click, noopener - Active timeout cancellation: query platform before expiring, recover paid orders - Singleton Stripe client, idempotency keys, Math.round for amounts - Handle async_payment events, return null for unknown webhook events - Set Checkout Session expires_at aligned with order timeout - Add cancelPayment to provider interface (Stripe: sessions.expire, EasyPay: no-op) - Enable stripe in frontend payment type list
20 lines
791 B
TypeScript
20 lines
791 B
TypeScript
import { NextRequest, NextResponse } from 'next/server';
|
|
import { verifyAdminToken, unauthorizedResponse } from '@/lib/admin-auth';
|
|
import { retryRecharge, OrderError } from '@/lib/order/service';
|
|
|
|
export async function POST(request: NextRequest, { params }: { params: Promise<{ id: string }> }) {
|
|
if (!verifyAdminToken(request)) return unauthorizedResponse();
|
|
|
|
try {
|
|
const { id } = await params;
|
|
await retryRecharge(id);
|
|
return NextResponse.json({ success: true });
|
|
} catch (error) {
|
|
if (error instanceof OrderError) {
|
|
return NextResponse.json({ error: error.message, code: error.code }, { status: error.statusCode });
|
|
}
|
|
console.error('Retry recharge error:', error);
|
|
return NextResponse.json({ error: '重试充值失败' }, { status: 500 });
|
|
}
|
|
}
|