import { ORGANISATION_MEMBER_ROLE_PERMISSIONS_MAP, ORGANISATION_USER_ACCOUNT_TYPE, } from '@documenso/lib/constants/organisations'; import { AppError, AppErrorCode } from '@documenso/lib/errors/app-error'; import { handleDocumentOwnershipOnDeletion } from '@documenso/lib/server-only/document/handle-document-ownership-on-deletion'; import { buildOrganisationWhereQuery } from '@documenso/lib/utils/organisations'; import { prisma } from '@documenso/prisma'; import { authenticatedProcedure } from '../trpc'; import { ZDeleteOrganisationRequestSchema, ZDeleteOrganisationResponseSchema, } from './delete-organisation.types'; export const deleteOrganisationRoute = authenticatedProcedure // .meta(deleteOrganisationMeta) .input(ZDeleteOrganisationRequestSchema) .output(ZDeleteOrganisationResponseSchema) .mutation(async ({ input, ctx }) => { const { organisationId } = input; const { user } = ctx; ctx.logger.info({ input: { organisationId, }, }); const organisation = await prisma.organisation.findFirst({ where: buildOrganisationWhereQuery({ organisationId, userId: user.id, roles: ORGANISATION_MEMBER_ROLE_PERMISSIONS_MAP['DELETE_ORGANISATION'], }), select: { id: true, owner: { select: { id: true, }, }, teams: { select: { id: true, documents: { select: { id: true, }, }, }, }, }, }); if (!organisation) { throw new AppError(AppErrorCode.UNAUTHORIZED, { message: 'You are not authorized to delete this organisation', }); } const documentIds = organisation.teams.flatMap((team) => team.documents.map((doc) => doc.id)); if (documentIds && documentIds.length > 0) { await handleDocumentOwnershipOnDeletion({ documentIds, organisationOwnerId: organisation.owner.id, }); } await prisma.$transaction(async (tx) => { await tx.account.deleteMany({ where: { type: ORGANISATION_USER_ACCOUNT_TYPE, provider: organisation.id, }, }); await tx.organisation.delete({ where: { id: organisation.id, }, }); }); });