Files
2026FIFAWorldCup/platform/web/app/api/analytics/daily-card-calendar/route.ts
QuantBot 64cae96d0d
Some checks failed
2026 World Cup Quant Platform - Production Deployment / Code Quality, Security Gate & Testing (push) Failing after 4m12s
2026 World Cup Quant Platform - Production Deployment / Deploy to Production VM via Gitea CD (push) Has been skipped
deploy: push latest version to production
2026-06-26 14:06:37 +08:00

44 lines
1.5 KiB
TypeScript

import { NextResponse } from 'next/server';
const ANALYTICS_BACKEND = process.env.ANALYTICS_BACKEND_URL || 'http://127.0.0.1:8000';
export const dynamic = 'force-dynamic';
export async function GET(request: Request) {
const url = new URL(request.url);
const startDate = url.searchParams.get('start_date') || '2026-06-11';
const endDate = url.searchParams.get('end_date');
if (!/^\d{4}-\d{2}-\d{2}$/.test(startDate)) {
return NextResponse.json({ message: '開始日期格式必須為 YYYY-MM-DD' }, { status: 400 });
}
if (endDate && !/^\d{4}-\d{2}-\d{2}$/.test(endDate)) {
return NextResponse.json({ message: '結束日期格式必須為 YYYY-MM-DD' }, { status: 400 });
}
const params = new URLSearchParams({ start_date: startDate });
if (endDate) params.set('end_date', endDate);
try {
const response = await fetch(`${ANALYTICS_BACKEND}/analytics/daily-card-calendar?${params.toString()}`, {
method: 'GET',
cache: 'no-store',
headers: {
'Content-Type': 'application/json',
},
});
if (!response.ok) {
const message = await response.text();
return NextResponse.json({ message }, { status: response.status });
}
const data = (await response.json()) as Record<string, unknown>;
return NextResponse.json(data);
} catch (error) {
const message = error instanceof Error ? error.message : '日期推薦摘要服務暫時無法連線';
return NextResponse.json({ message }, { status: 502 });
}
}