25 lines
854 B
TypeScript
25 lines
854 B
TypeScript
import { NextResponse } from 'next/server';
|
|
|
|
const ANALYTICS_BACKEND = process.env.ANALYTICS_BACKEND_URL || 'http://127.0.0.1:8000';
|
|
|
|
export async function GET() {
|
|
try {
|
|
const response = await fetch(`${ANALYTICS_BACKEND}/analytics/gemini-usage`, {
|
|
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({ generated_at: new Date().toISOString(), ...data });
|
|
} catch (error) {
|
|
const message = error instanceof Error ? error.message : 'Gemini 用量服務暫時無法連線';
|
|
return NextResponse.json({ message }, { status: 502 });
|
|
}
|
|
}
|