Files
harheimertc/.output/server/chunks/routes/api/termine-manage.delete.mjs

67 lines
1.8 KiB
JavaScript

import { d as defineEventHandler, g as getCookie, c as createError, f as getQuery } from '../../nitro/nitro.mjs';
import { b as verifyToken, e as getUserById } from '../../_/auth.mjs';
import { d as deleteTermin } from '../../_/termine.mjs';
import 'node:http';
import 'node:https';
import 'node:events';
import 'node:buffer';
import 'node:fs';
import 'node:path';
import 'node:crypto';
import 'node:url';
import 'bcryptjs';
import 'jsonwebtoken';
import 'fs';
import 'path';
import 'crypto';
const termineManage_delete = defineEventHandler(async (event) => {
try {
const token = getCookie(event, "auth_token");
if (!token) {
throw createError({
statusCode: 401,
message: "Nicht authentifiziert."
});
}
const decoded = verifyToken(token);
if (!decoded) {
throw createError({
statusCode: 401,
message: "Ung\xFCltiges Token."
});
}
const user = await getUserById(decoded.id);
if (!user || user.role !== "admin" && user.role !== "vorstand") {
throw createError({
statusCode: 403,
message: "Keine Berechtigung zum L\xF6schen von Terminen."
});
}
const query = getQuery(event);
const { datum, titel, beschreibung, kategorie } = query;
if (!datum || !titel) {
throw createError({
statusCode: 400,
message: "Datum und Titel sind erforderlich."
});
}
await deleteTermin({
datum,
titel,
beschreibung: beschreibung || "",
kategorie: kategorie || "Sonstiges"
});
return {
success: true,
message: "Termin erfolgreich gel\xF6scht."
};
} catch (error) {
console.error("Fehler beim L\xF6schen des Termins:", error);
throw error;
}
});
export { termineManage_delete as default };
//# sourceMappingURL=termine-manage.delete.mjs.map