import { and, eq, or } from 'drizzle-orm'; import useDatabase from '~/composables/useDatabase'; import { campaignCharactersTable, campaignMembersTable, campaignTable, characterTable } from '~/db/schema'; export default defineEventHandler(async (e) => { const _id = getRouterParam(e, "id"); if(!_id) { setResponseStatus(e, 400); return; } const id = parseInt(_id, 10); const _campaign_id = getRouterParam(e, "cid"); if(!_campaign_id) { setResponseStatus(e, 400); return; } const campaign_id = parseInt(_campaign_id, 10); const session = await getUserSession(e); if(!session.user || session.user.state !== 1) { setResponseStatus(e, 401); return; } const db = useDatabase(); const campaign = db.select({ id: campaignTable.id }).from(campaignTable).leftJoin(campaignMembersTable, eq(campaignTable.id, campaignMembersTable.id)).where(and(eq(campaignTable.id, campaign_id), or(eq(campaignMembersTable.user, session.user.id), eq(campaignTable.owner, session.user.id)))).get(); if(!campaign || campaign.id !== campaign_id) return setResponseStatus(e, 404); const character = db.select({ id: campaignCharactersTable.character }).from(campaignCharactersTable).where(and(eq(campaignCharactersTable.id, campaign_id), eq(campaignCharactersTable.character, id))).get(); if(!character || character.id !== id) return setResponseStatus(e, 403); db.delete(campaignCharactersTable).where(and(eq(campaignCharactersTable.id, campaign_id), eq(campaignCharactersTable.character, id))).run(); setResponseStatus(e, 200); return; });