import multer from 'multer' import fs from 'fs/promises' import path from 'path' // Multer-Konfiguration für PDF-Uploads const storage = multer.diskStorage({ destination: (req, file, cb) => { cb(null, 'public/documents/') }, filename: (req, file, cb) => { cb(null, 'satzung.pdf') } }) const upload = multer({ storage, fileFilter: (req, file, cb) => { if (file.mimetype === 'application/pdf') { cb(null, true) } else { cb(new Error('Nur PDF-Dateien sind erlaubt'), false) } }, limits: { fileSize: 10 * 1024 * 1024 // 10MB Limit } }) export default defineEventHandler(async (event) => { if (event.method !== 'POST') { throw createError({ statusCode: 405, statusMessage: 'Method Not Allowed' }) } try { // Multer-Middleware für File-Upload await new Promise((resolve, reject) => { upload.single('pdf')(event.node.req, event.node.res, (err) => { if (err) reject(err) else resolve() }) }) const file = event.node.req.file if (!file) { throw createError({ statusCode: 400, statusMessage: 'Keine PDF-Datei hochgeladen' }) } // Für jetzt: Einfacher Platzhalter-Text statt PDF-Parsing // TODO: PDF-Parsing später implementieren const htmlContent = `
Die Satzung wurde erfolgreich hochgeladen.
Datei: ${file.originalname}
Größe: ${(file.size / 1024).toFixed(2)} KB
Hinweis: Der Text-Inhalt wird automatisch extrahiert, sobald das PDF-Parsing implementiert ist.
` // Config aktualisieren const configPath = path.join(process.cwd(), 'server/data/config.json') const configData = JSON.parse(await fs.readFile(configPath, 'utf-8')) configData.seiten.satzung = { pdfUrl: '/documents/satzung.pdf', content: htmlContent } await fs.writeFile(configPath, JSON.stringify(configData, null, 2)) return { success: true, message: 'Satzung erfolgreich hochgeladen und verarbeitet', pdfUrl: '/documents/satzung.pdf' } } catch (error) { console.error('PDF Upload Error:', error) throw createError({ statusCode: 500, statusMessage: error.message || 'Fehler beim Verarbeiten der PDF-Datei' }) } }) // TODO: PDF-Parsing-Funktion später implementieren // function convertTextToHtml(text) { // // Einfache Text-zu-HTML-Konvertierung // let html = text // .replace(/\n\n+/g, '') // Absätze
// .replace(/\n/g, '
') // Zeilenumbrüche
// .replace(/^(.+)$/gm, '
$1
') // Alle Zeilen in Paragraphen // // // Überschriften erkennen (einfache Heuristik) // html = html.replace(/(§\s*\d+.*?)<\/p>/g, '
(\d+\.\s+.*?)<\/p>/g, '