Campaign sheet start

This commit is contained in:
2025-11-16 23:43:54 +01:00
parent dfbb31595e
commit d8480e7366
11 changed files with 249 additions and 126 deletions

View File

@@ -33,8 +33,6 @@ export default defineEventHandler(async (e) => {
tx.update(campaignTable).set({ link: cryptURI('campaign', id) }).where(eq(campaignTable.id, id)).run();
tx.insert(campaignMembersTable).values({ id, rights: 'dm', user: session.user!.id }).run();
return id;
});

View File

@@ -1,5 +1,6 @@
import { eq, not, sql } from 'drizzle-orm';
import useDatabase from '~/composables/useDatabase';
import type { Campaign } from '~/types/campaign';
export default defineEventHandler(async (e) => {
const id = getRouterParam(e, "id");
@@ -19,17 +20,18 @@ export default defineEventHandler(async (e) => {
const db = useDatabase();
const data = db.query.campaignTable.findFirst({
with: {
members: { with: { member: { columns: { username: true, id: true } } }, columns: { }, where: ({ rights }) => not(eq(rights, 'dm')), extras: { 'characters': sql`NULL`.as('characters') } },
members: { with: { member: { columns: { username: true, id: true } } }, columns: { id: false, rights: false, user: false }, extras: { 'characters': sql`NULL`.as('characters') } },
characters: { with: { character: { columns: { id: true, name: true, owner: true } } } },
owner: { columns: { username: true, id: true } },
logs: { columns: { details: true, from: true, timestamp: true, type: true }, orderBy: ({ timestamp }) => timestamp }
},
where: ({ id: _id }) => eq(_id, parseInt(id, 10)),
}).sync();
if(data && (data.owner.id === session.user.id || data.members.find(e => e.member?.id === session.user!.id)))
{
data.members.forEach(e => e.characters = data.characters.filter(_e => _e.character?.owner === e.member?.id))
return data;
data.members.forEach(e => e.characters = data.characters.filter(_e => _e.character?.owner === e.member?.id));
return data as Campaign;
}
else if(!data) return setResponseStatus(e, 404);
else return setResponseStatus(e, 403);