65 lines
1.5 KiB
TypeScript
65 lines
1.5 KiB
TypeScript
|
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;
|
||
|
}
|