klg-asutk-app/app/api/notifications/email/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

57 lines
1.6 KiB
TypeScript

export const dynamic = "force-dynamic";
import { NextRequest, NextResponse } from 'next/server';
import { sendCriticalRiskEmail, sendUpcomingAuditEmail } from '@/lib/notifications/email-service';
import { handleError } from '@/lib/error-handler';
import { rateLimit, getRateLimitIdentifier } from '@/lib/rate-limit';
/**
* POST /api/notifications/email - Отправка email уведомления
*/
export async function POST(request: NextRequest) {
try {
// Rate limiting
const identifier = getRateLimitIdentifier(request);
const rateLimitResult = rateLimit(identifier);
if (!rateLimitResult.allowed) {
return NextResponse.json(
{ error: 'Слишком много запросов' },
{ status: 429 }
);
}
const body = await request.json();
const { type, ...data } = body;
let success = false;
if (type === 'critical_risk') {
success = await sendCriticalRiskEmail(
data.userEmail,
data.riskTitle,
data.aircraftRegistration,
data.riskId
);
} else if (type === 'upcoming_audit') {
success = await sendUpcomingAuditEmail(
data.userEmail,
data.auditType,
data.organizationName,
data.auditDate,
data.daysUntil
);
} else {
return NextResponse.json(
{ error: 'Неверный тип уведомления' },
{ status: 400 }
);
}
return NextResponse.json({ success });
} catch (error) {
return handleError(error, {
path: '/api/notifications/email',
method: 'POST',
});
}
}