59 lines
1.7 KiB
JavaScript
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
|