Files
harheimertc/server/api/cms/satzung-upload.post.js

104 lines
2.9 KiB
JavaScript

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 = `
<h2>Satzung</h2>
<p>Die Satzung wurde erfolgreich hochgeladen.</p>
<p><strong>Datei:</strong> ${file.originalname}</p>
<p><strong>Größe:</strong> ${(file.size / 1024).toFixed(2)} KB</p>
<p><em>Hinweis: Der Text-Inhalt wird automatisch extrahiert, sobald das PDF-Parsing implementiert ist.</em></p>
`
// 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, '</p><p>') // Absätze
// .replace(/\n/g, '<br>') // Zeilenumbrüche
// .replace(/^(.+)$/gm, '<p>$1</p>') // Alle Zeilen in Paragraphen
//
// // Überschriften erkennen (einfache Heuristik)
// html = html.replace(/<p>(§\s*\d+.*?)<\/p>/g, '<h3>$1</h3>')
// html = html.replace(/<p>(\d+\.\s+.*?)<\/p>/g, '<h4>$1</h4>')
//
// return `<h2>Satzung</h2>${html}`
// }