owltide/server/api/auth/session.delete.ts

23 lines
633 B
TypeScript
Raw Normal View History

/*
SPDX-FileCopyrightText: © 2025 Hornwitser <code@hornwitser.no>
SPDX-License-Identifier: AGPL-3.0-or-later
*/
import { readUsers } from "~/server/database";
import { cancelSessionStreams } from "~/server/streams";
2025-03-07 23:53:57 +01:00
export default defineEventHandler(async (event) => {
const session = await getServerSession(event, true);
2025-03-07 23:53:57 +01:00
if (session) {
const users = await readUsers();
const account = users.find(user => user.id === session.accountId);
if (account?.type === "anonymous") {
2025-03-07 23:53:57 +01:00
throw createError({
status: 409,
message: "Cannot log out of an anonymous account",
});
}
}
await clearServerSession(event);
})