Files
harheimertc/.output/server/chunks/routes/api/cms/users/deactivate.post.mjs

59 lines
1.7 KiB
JavaScript

import { d as defineEventHandler, g as getCookie, c as createError, r as readBody } from '../../../../nitro/nitro.mjs';
import { a as getUserFromToken, r as readUsers, w as writeUsers } from '../../../../_/auth.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 '../../../../_/encryption.mjs';
import 'crypto';
const deactivate_post = defineEventHandler(async (event) => {
try {
const token = getCookie(event, "auth_token");
const currentUser = await getUserFromToken(token);
if (!currentUser || currentUser.role !== "admin" && currentUser.role !== "vorstand") {
throw createError({
statusCode: 403,
message: "Zugriff verweigert"
});
}
const body = await readBody(event);
const { userId } = body;
if (userId === currentUser.id) {
throw createError({
statusCode: 400,
message: "Sie k\xF6nnen sich nicht selbst deaktivieren"
});
}
const users = await readUsers();
const user = users.find((u) => u.id === userId);
if (!user) {
throw createError({
statusCode: 404,
message: "Benutzer nicht gefunden"
});
}
user.active = false;
const updatedUsers = users.map((u) => u.id === userId ? user : u);
await writeUsers(updatedUsers);
return {
success: true,
message: "Benutzer wurde deaktiviert"
};
} catch (error) {
console.error("Fehler beim Deaktivieren:", error);
throw error;
}
});
export { deactivate_post as default };
//# sourceMappingURL=deactivate.post.mjs.map