import multer from 'multer' import fs from 'fs/promises' import path from 'path' import { createRequire } from 'module' const require = createRequire(import.meta.url) const pdfParse = require('pdf-parse') // 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' }) } // PDF-Text extrahieren const pdfBuffer = await fs.readFile(file.path) const pdfData = await pdfParse(pdfBuffer) // Text in HTML-Format konvertieren (einfache Formatierung) const htmlContent = convertTextToHtml(pdfData.text) // Config aktualisieren const configPath = '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' }) } }) 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, '

$1

') html = html.replace(/

(\d+\.\s+.*?)<\/p>/g, '

$1

') return `

Satzung

${html}` }