klg-asutk-app/app/api/tracing/route.ts
Yuriy 0150aba4f5 Consolidation: KLG ASUTK + PAPA integration
- Unify API: lib/api.ts uses /api/v1, inbox uses /api/inbox (rewrites)
- Remove localhost refs: openapi, inbox page
- Add rewrites: /api/inbox|tmc -> inbox-server, /api/v1 -> FastAPI
- Add stub routes: knowledge/insights, recommendations, search, log-error
- Transfer from PAPA: prompts (inspection, tmc), scripts, supabase, data/tmc-requests
- Fix inbox-server: ORDER BY created_at, package.json
- Remove redundant app/api/inbox/files route (rewrites handle it)
- knowledge/ in gitignore (large PDFs)

Co-authored-by: Cursor <cursoragent@cursor.com>
2026-02-08 17:18:31 +03:00

54 lines
1.6 KiB
TypeScript

export const dynamic = "force-dynamic";
import { NextRequest, NextResponse } from 'next/server';
import { tracer } from '@/lib/tracing/tracer';
import { rateLimit, getRateLimitIdentifier } from '@/lib/rate-limit';
export async function GET(request: NextRequest) {
try {
const rateLimitResult = rateLimit(getRateLimitIdentifier(request), 100, 60000);
if (!rateLimitResult.allowed) {
return NextResponse.json(
{ error: 'Слишком много запросов' },
{ status: 429 }
);
}
const { searchParams } = new URL(request.url);
const traceId = searchParams.get('traceId');
if (traceId) {
// Получить конкретный trace
const trace = tracer.exportTrace(traceId);
if (!trace) {
return NextResponse.json(
{ error: 'Trace not found' },
{ status: 404 }
);
}
return NextResponse.json(trace);
}
// Получить все traces (последние 100)
const allTraces = tracer.getAllTraces();
const traces = Array.from(allTraces.entries())
.slice(-100)
.map(([traceId, spans]) => ({
traceId,
spanCount: spans.length,
duration: spans[spans.length - 1]?.duration || 0,
status: spans[spans.length - 1]?.status || 'unknown',
operation: spans[0]?.operation || 'unknown',
}));
return NextResponse.json({
traces,
total: allTraces.size,
});
} catch (error: any) {
return NextResponse.json(
{ error: error.message || 'Internal server error' },
{ status: 500 }
);
}
}