cal/packages/lib/hasEditPermissionForUser.ts
2023-09-14 09:18:19 -03:00

66 lines
1.6 KiB
TypeScript

import { prisma } from "@calcom/prisma";
import { MembershipRole } from "@calcom/prisma/enums";
import type { TrpcSessionUser } from "@calcom/trpc/server/trpc";
const ROLES_WITH_EDIT_PERMISSION = [MembershipRole.ADMIN, MembershipRole.OWNER] as MembershipRole[];
type InputOptions = {
ctx: {
user: NonNullable<TrpcSessionUser>;
};
input: {
memberId: number;
};
};
export async function hasEditPermissionForUserID({ ctx, input }: InputOptions) {
const { user } = ctx;
const authedUsersTeams = await prisma.membership.findMany({
where: {
userId: user.id,
accepted: true,
role: {
in: [MembershipRole.ADMIN, MembershipRole.OWNER],
},
},
});
const targetUsersTeams = await prisma.membership.findMany({
where: {
userId: input.memberId,
accepted: true,
},
});
const teamIdOverlaps = authedUsersTeams.some((authedTeam) => {
return targetUsersTeams.some((targetTeam) => targetTeam.teamId === authedTeam.teamId);
});
return teamIdOverlaps;
}
export async function hasReadPermissionsForUserId({ ctx, input }: InputOptions) {
const { user } = ctx;
const authedUsersTeams = await prisma.membership.findMany({
where: {
userId: user.id,
accepted: true,
},
});
const targetUsersTeams = await prisma.membership.findMany({
where: {
userId: input.memberId,
accepted: true,
},
});
const teamIdOverlaps = authedUsersTeams.some((authedTeam) => {
return targetUsersTeams.some((targetTeam) => targetTeam.teamId === authedTeam.teamId);
});
return teamIdOverlaps;
}