mirror of
https://github.com/documenso/documenso.git
synced 2025-11-12 15:53:02 +10:00
86 lines
1.9 KiB
TypeScript
86 lines
1.9 KiB
TypeScript
import { DocumentVisibility, TeamMemberRole } from '@prisma/client';
|
|
import { match } from 'ts-pattern';
|
|
|
|
import { AppError, AppErrorCode } from '@documenso/lib/errors/app-error';
|
|
import { prisma } from '@documenso/prisma';
|
|
|
|
export interface DeleteFolderOptions {
|
|
userId: number;
|
|
teamId?: number;
|
|
folderId: string;
|
|
}
|
|
|
|
export const deleteFolder = async ({ userId, teamId, folderId }: DeleteFolderOptions) => {
|
|
let teamMemberRole: TeamMemberRole | null = null;
|
|
|
|
if (teamId) {
|
|
const team = await prisma.team.findFirst({
|
|
where: {
|
|
id: teamId,
|
|
members: {
|
|
some: {
|
|
userId,
|
|
},
|
|
},
|
|
},
|
|
include: {
|
|
members: {
|
|
where: {
|
|
userId,
|
|
},
|
|
select: {
|
|
role: true,
|
|
},
|
|
},
|
|
},
|
|
});
|
|
|
|
if (!team) {
|
|
throw new AppError(AppErrorCode.NOT_FOUND, {
|
|
message: 'Team not found',
|
|
});
|
|
}
|
|
|
|
teamMemberRole = team.members[0]?.role ?? null;
|
|
}
|
|
|
|
const folder = await prisma.folder.findFirst({
|
|
where: {
|
|
id: folderId,
|
|
userId,
|
|
teamId,
|
|
},
|
|
include: {
|
|
documents: true,
|
|
subfolders: true,
|
|
templates: true,
|
|
},
|
|
});
|
|
|
|
if (!folder) {
|
|
throw new AppError(AppErrorCode.NOT_FOUND, {
|
|
message: 'Folder not found',
|
|
});
|
|
}
|
|
|
|
if (teamId && teamMemberRole) {
|
|
const hasPermission = match(teamMemberRole)
|
|
.with(TeamMemberRole.ADMIN, () => true)
|
|
.with(TeamMemberRole.MANAGER, () => folder.visibility !== DocumentVisibility.ADMIN)
|
|
.with(TeamMemberRole.MEMBER, () => folder.visibility === DocumentVisibility.EVERYONE)
|
|
.otherwise(() => false);
|
|
|
|
if (!hasPermission) {
|
|
throw new AppError(AppErrorCode.UNAUTHORIZED, {
|
|
message: 'You do not have permission to delete this folder',
|
|
});
|
|
}
|
|
}
|
|
|
|
return await prisma.folder.delete({
|
|
where: {
|
|
id: folderId,
|
|
},
|
|
});
|
|
};
|