Implement member management enhancements; add bulk import functionality and duplicate checking based on geburtsdatum. Update API to support new fields and improve error handling for member data submissions. Refactor member-related components for better user experience and data validation.
This commit is contained in:
@@ -1,4 +1,4 @@
|
||||
import { d as defineEventHandler, g as getCookie, c as createError, r as readBody } from '../../nitro/nitro.mjs';
|
||||
import { d as defineEventHandler, g as getCookie, b as getHeader, c as createError, r as readBody } from '../../nitro/nitro.mjs';
|
||||
import { b as verifyToken, e as getUserById } from '../../_/auth.mjs';
|
||||
import { s as saveMember } from '../../_/members.mjs';
|
||||
import 'node:http';
|
||||
@@ -18,11 +18,17 @@ import 'crypto';
|
||||
|
||||
const members_post = defineEventHandler(async (event) => {
|
||||
try {
|
||||
const token = getCookie(event, "auth_token");
|
||||
let token = getCookie(event, "auth_token");
|
||||
if (!token) {
|
||||
const authHeader = getHeader(event, "authorization");
|
||||
if (authHeader && authHeader.startsWith("Bearer ")) {
|
||||
token = authHeader.substring(7);
|
||||
}
|
||||
}
|
||||
if (!token) {
|
||||
throw createError({
|
||||
statusCode: 401,
|
||||
message: "Nicht authentifiziert."
|
||||
message: "Nicht authentifiziert. Bitte Token im Cookie oder Authorization-Header bereitstellen."
|
||||
});
|
||||
}
|
||||
const decoded = verifyToken(token);
|
||||
@@ -33,36 +39,65 @@ const members_post = defineEventHandler(async (event) => {
|
||||
});
|
||||
}
|
||||
const user = await getUserById(decoded.id);
|
||||
if (!user || user.role !== "admin" && user.role !== "vorstand") {
|
||||
if (!user) {
|
||||
throw createError({
|
||||
statusCode: 401,
|
||||
message: "Benutzer nicht gefunden."
|
||||
});
|
||||
}
|
||||
if (user.role !== "admin" && user.role !== "vorstand") {
|
||||
throw createError({
|
||||
statusCode: 403,
|
||||
message: "Keine Berechtigung zum Bearbeiten von Mitgliedern."
|
||||
message: "Keine Berechtigung zum Hinzuf\xFCgen/Bearbeiten von Mitgliedern. Erforderlich: admin oder vorstand Rolle."
|
||||
});
|
||||
}
|
||||
const body = await readBody(event);
|
||||
const { id, firstName, lastName, email, phone, address, notes } = body;
|
||||
const { id, firstName, lastName, geburtsdatum, email, phone, address, notes } = body;
|
||||
if (!firstName || !lastName) {
|
||||
throw createError({
|
||||
statusCode: 400,
|
||||
message: "Vorname und Nachname sind erforderlich."
|
||||
});
|
||||
}
|
||||
await saveMember({
|
||||
id: id || void 0,
|
||||
firstName,
|
||||
lastName,
|
||||
email: email || "",
|
||||
phone: phone || "",
|
||||
address: address || "",
|
||||
notes: notes || ""
|
||||
});
|
||||
return {
|
||||
success: true,
|
||||
message: "Mitglied erfolgreich gespeichert."
|
||||
};
|
||||
if (!geburtsdatum) {
|
||||
throw createError({
|
||||
statusCode: 400,
|
||||
message: "Geburtsdatum ist erforderlich, um Duplikate zu vermeiden."
|
||||
});
|
||||
}
|
||||
try {
|
||||
await saveMember({
|
||||
id: id || void 0,
|
||||
firstName,
|
||||
lastName,
|
||||
geburtsdatum: geburtsdatum || "",
|
||||
email: email || "",
|
||||
phone: phone || "",
|
||||
address: address || "",
|
||||
notes: notes || ""
|
||||
});
|
||||
return {
|
||||
success: true,
|
||||
message: "Mitglied erfolgreich gespeichert."
|
||||
};
|
||||
} catch (memberError) {
|
||||
if (memberError.message && memberError.message.includes("existiert bereits")) {
|
||||
throw createError({
|
||||
statusCode: 409,
|
||||
message: memberError.message
|
||||
});
|
||||
}
|
||||
throw memberError;
|
||||
}
|
||||
} catch (error) {
|
||||
console.error("Fehler beim Speichern des Mitglieds:", error);
|
||||
throw error;
|
||||
if (error.statusCode) {
|
||||
throw error;
|
||||
}
|
||||
throw createError({
|
||||
statusCode: error.statusCode || 500,
|
||||
message: error.message || "Fehler beim Speichern des Mitglieds."
|
||||
});
|
||||
}
|
||||
});
|
||||
|
||||
|
||||
Reference in New Issue
Block a user