'use server'; import { auth } from '@clerk/nextjs/server'; import { revalidatePath, revalidateTag } from 'next/cache'; import { ACTION, ENTITY_TYPE } from '@prisma/client'; import { db } from '@/lib/db'; import { createAuditLog } from '@/lib/create-audit-log'; import { createSafeAction } from '@/lib/create-safe-action'; import { InputType, ReturnType } from './types'; import { UpdateCard } from './schema'; const handler = async (data: InputType): Promise => { const { userId, orgId } = await auth(); if (!userId || !orgId) return { error: 'Unauthorized' }; const { id, boardId, startedAt, dueDate, ...values } = data; let card; try { card = await db.card.update({ where: { id, list: { board: { orgId, }, }, }, data: { ...values, dueDate: dueDate, startedAt: startedAt, }, }); await createAuditLog({ entityTitle: card.title, entityType: ENTITY_TYPE.CARD, entityId: card.id, action: ACTION.UPDATE, }); } catch (error) { return { error: 'Failed to update card', }; } revalidateTag(`card-${id}`); revalidatePath(`/board/${boardId}`); return { data: card }; }; export const updateCard = createSafeAction(UpdateCard, handler);