owltide/server/api/auth/account.post.ts

65 lines
1.5 KiB
TypeScript
Raw Normal View History

/*
SPDX-FileCopyrightText: © 2025 Hornwitser <code@hornwitser.no>
SPDX-License-Identifier: AGPL-3.0-or-later
*/
import { readUsers, writeUsers, nextUserId, type ServerUser } from "~/server/database";
import { broadcastEvent } from "~/server/streams";
2025-03-07 23:53:57 +01:00
export default defineEventHandler(async (event) => {
let session = await getServerSession(event);
2025-03-07 23:53:57 +01:00
if (session) {
throw createError({
status: 409,
message: "Cannot create account while having an active session."
});
}
const formData = await readFormData(event);
const name = formData.get("name");
const users = await readUsers();
let user: ServerUser;
2025-03-07 23:53:57 +01:00
if (typeof name === "string") {
if (name === "") {
throw createError({
status: 400,
message: "Name cannot be blank",
});
}
if (users.some(user => user.name && user.name.toLowerCase() === name.toLowerCase())) {
2025-03-07 23:53:57 +01:00
throw createError({
status: 409,
message: "User already exists",
});
}
const firstUser = users.every(user => user.type === "anonymous");
user = {
id: await nextUserId(),
updatedAt: new Date().toISOString(),
type: firstUser ? "admin" : "regular",
2025-03-07 23:53:57 +01:00
name,
};
} else if (name === null) {
user = {
id: await nextUserId(),
updatedAt: new Date().toISOString(),
2025-03-07 23:53:57 +01:00
type: "anonymous",
};
} else {
throw createError({
status: 400,
message: "Invalid name",
});
}
users.push(user);
await writeUsers(users);
await broadcastEvent({
type: "user-update",
data: user,
});
await setServerSession(event, user);
2025-03-07 23:53:57 +01:00
})