fix: resolve all ESLint errors in backend and frontend

Backend 958→0 errors, frontend 98→0 errors. Builds and tsc clean.

Echte Fixes:
- Auth: AuthenticatedUser/AuthenticatedRequest, JwtStrategy + alle 5
  Controller von `@Request() req: any` auf typisierten Request umgestellt
- Error-Handling: neuer getErrorMessage/Stack/Code/getResponseData-Helper;
  alle 50 `catch (err: any)`-Blöcke auf `unknown` + Helper umgestellt
- 24 echte Bugs: require-await, require-imports→ES-Imports, useless-escape,
  misused-promises, tote Imports/Vars, leere catch-Blöcke kommentiert
- document-pipeline: OCR-Ergebnis wird nicht gespeichert (als TODO markiert)

Pragmatisch auf warn herabgestuft (untypisierte Paperless-NGX-API):
no-unsafe-*, restrict-template-expressions, no-base-to-string,
no-explicit-any (FE), react-refresh/only-export-components

Co-Authored-By: Claude Opus 4.8 <noreply@anthropic.com>
This commit is contained in:
2026-06-09 21:33:37 +02:00
parent d96e06e86d
commit 07dfd7e840
43 changed files with 399 additions and 204 deletions
@@ -10,6 +10,7 @@ import {
type InboxSource,
type StoredQrCode,
} from '../database/entities/inbox-document.entity';
import { getErrorMessage, getErrorCode } from '../common/error.util';
import { PageCacheService } from '../barcode/page-cache.service';
interface LegacyScanRow {
@@ -41,10 +42,10 @@ export class InboxMigrationService implements OnApplicationBootstrap {
withFileTypes: true,
});
subdirs = entries.filter((e) => e.isDirectory()).map((e) => e.name);
} catch (err: any) {
if (err.code !== 'ENOENT') {
} catch (err: unknown) {
if (getErrorCode(err) !== 'ENOENT') {
this.logger.warn(
`Migration: ${this.legacyRoot} nicht lesbar: ${err.message}`,
`Migration: ${this.legacyRoot} nicht lesbar: ${getErrorMessage(err)}`,
);
}
return;
@@ -56,8 +57,10 @@ export class InboxMigrationService implements OnApplicationBootstrap {
let files: string[];
try {
files = await fs.readdir(dir);
} catch (err: any) {
this.logger.warn(`Migration: ${dir} nicht lesbar: ${err.message}`);
} catch (err: unknown) {
this.logger.warn(
`Migration: ${dir} nicht lesbar: ${getErrorMessage(err)}`,
);
continue;
}
@@ -67,9 +70,9 @@ export class InboxMigrationService implements OnApplicationBootstrap {
try {
await this.migrateFile(src, subdir, name);
migrated += 1;
} catch (err: any) {
} catch (err: unknown) {
this.logger.error(
`Migration fehlgeschlagen (${src}): ${err.message}`,
`Migration fehlgeschlagen (${src}): ${getErrorMessage(err)}`,
);
}
}
@@ -116,8 +119,8 @@ export class InboxMigrationService implements OnApplicationBootstrap {
try {
await fs.rename(src, dest);
return;
} catch (err: any) {
if (err.code !== 'EXDEV') throw err;
} catch (err: unknown) {
if (getErrorCode(err) !== 'EXDEV') throw err;
}
await fs.copyFile(src, dest);
try {