klg-asutk-app/app/error.tsx
Yuriy aa052763f6 Безопасность и качество: 8 исправлений + обновления
- .env.example: полный шаблон, защита секретов
- .gitignore: явное исключение .env.* и секретов
- layout.tsx: XSS — заменён dangerouslySetInnerHTML на next/script для SW
- ESLint: no-console error (allow warn/error), ignore scripts/
- scripts/remove-console-logs.js: очистка console.log без glob
- backend/routes/modules: README с планом рефакторинга крупных файлов
- SECURITY.md: гид по секретам, XSS, CORS, auth, линту
- .husky/pre-commit: запуск npm run lint

+ прочие правки приложения и бэкенда

Co-authored-by: Cursor <cursoragent@cursor.com>
2026-02-14 21:29:16 +03:00

54 lines
1.2 KiB
TypeScript

/**
* Глобальная страница ошибок Next.js
*/
'use client';
import { useEffect } from 'react';
import ErrorDisplay from '@/components/ErrorDisplay';
import { getUserFriendlyError } from '@/lib/errors/user-friendly-messages';
import { captureException } from '@/lib/monitoring/sentry';
export default function Error({
error,
reset,
}: {
error: Error & { digest?: string };
reset: () => void;
}) {
useEffect(() => {
// Логирование ошибки
console.error('Global error:', error);
// Отправка в Sentry
if (process.env.NEXT_PUBLIC_SENTRY_DSN) {
try {
captureException(error, {
digest: error.digest,
component: 'global-error',
});
} catch (e) {
// Игнорируем ошибки Sentry
}
}
}, [error]);
const friendlyError = getUserFriendlyError(error);
return (
<div
>
<div className="max-w-xl">
<ErrorDisplay
title={friendlyError.title}
message={friendlyError.message}
type={friendlyError.type}
onRetry={reset}
showDetails={process.env.NODE_ENV === 'development'}
details={error.stack}
/>
</div>
</div>
);
}