import { Request, Response } from 'express'; import * as providerService from '../services/provider.service.js'; import { logChange } from '../services/audit.service.js'; import { ApiResponse } from '../types/index.js'; export async function getProviders(req: Request, res: Response): Promise { try { const includeInactive = req.query.includeInactive === 'true'; const providers = await providerService.getAllProviders(includeInactive); res.json({ success: true, data: providers } as ApiResponse); } catch (error) { res.status(500).json({ success: false, error: 'Fehler beim Laden der Anbieter', } as ApiResponse); } } export async function getProvider(req: Request, res: Response): Promise { try { // `req.params.id` ist Pfad-Segment – bei /api/providers/email landet // hier der String "email", den parseInt zu NaN macht. Ohne Validierung // fuhr Prisma dann gegen `WHERE id = NaN` und warf 500. // Pentest 2026-05-20, 29.5: explizit 404 statt 500. Andere Sub-Routes // wie /api/providers//tariffs greifen weiter wie gehabt. const id = parseInt(req.params.id, 10); if (!Number.isFinite(id) || id < 1) { res.status(404).json({ success: false, error: 'Anbieter nicht gefunden', } as ApiResponse); return; } const provider = await providerService.getProviderById(id); if (!provider) { res.status(404).json({ success: false, error: 'Anbieter nicht gefunden', } as ApiResponse); return; } res.json({ success: true, data: provider } as ApiResponse); } catch (error) { res.status(500).json({ success: false, error: 'Fehler beim Laden des Anbieters', } as ApiResponse); } } export async function createProvider(req: Request, res: Response): Promise { try { const provider = await providerService.createProvider(req.body); await logChange({ req, action: 'CREATE', resourceType: 'Provider', resourceId: provider.id.toString(), label: `Anbieter ${provider.name} angelegt`, }); res.status(201).json({ success: true, data: provider } as ApiResponse); } catch (error) { res.status(400).json({ success: false, error: error instanceof Error ? error.message : 'Fehler beim Erstellen des Anbieters', } as ApiResponse); } } export async function updateProvider(req: Request, res: Response): Promise { try { const provider = await providerService.updateProvider(parseInt(req.params.id), req.body); await logChange({ req, action: 'UPDATE', resourceType: 'Provider', resourceId: provider.id.toString(), label: `Anbieter ${provider.name} aktualisiert`, }); res.json({ success: true, data: provider } as ApiResponse); } catch (error) { res.status(400).json({ success: false, error: error instanceof Error ? error.message : 'Fehler beim Aktualisieren des Anbieters', } as ApiResponse); } } export async function deleteProvider(req: Request, res: Response): Promise { try { const providerId = parseInt(req.params.id); const provider = await providerService.getProviderById(providerId); await providerService.deleteProvider(providerId); await logChange({ req, action: 'DELETE', resourceType: 'Provider', resourceId: providerId.toString(), label: `Anbieter ${provider?.name || providerId} gelöscht`, }); res.json({ success: true, message: 'Anbieter gelöscht' } as ApiResponse); } catch (error) { res.status(400).json({ success: false, error: error instanceof Error ? error.message : 'Fehler beim Löschen des Anbieters', } as ApiResponse); } }