Files
formbricks-formbricks/packages/lib/organization/auth.ts
Piyush Gupta 1af1a92fec feat: granular team roles (#3975)
Co-authored-by: Matthias Nannt <mail@matthiasnannt.com>
Co-authored-by: Dhruwang <dhruwangjariwala18@gmail.com>
Co-authored-by: Johannes <72809645+jobenjada@users.noreply.github.com>
Co-authored-by: Johannes <johannes@formbricks.com>
2024-11-08 06:03:14 +00:00

72 lines
2.2 KiB
TypeScript

import "server-only";
import { ZId } from "@formbricks/types/common";
import { cache } from "../cache";
import { getMembershipByUserIdOrganizationId } from "../membership/service";
import { getAccessFlags } from "../membership/utils";
import { organizationCache } from "../organization/cache";
import { validateInputs } from "../utils/validate";
import { getOrganizationsByUserId } from "./service";
export const canUserAccessOrganization = (userId: string, organizationId: string): Promise<boolean> =>
cache(
async () => {
validateInputs([userId, ZId], [organizationId, ZId]);
try {
const userOrganizations = await getOrganizationsByUserId(userId);
const givenOrganizationExists = userOrganizations.filter(
(organization) => (organization.id = organizationId)
);
if (!givenOrganizationExists) {
return false;
}
return true;
} catch (error) {
throw error;
}
},
[`canUserAccessOrganization-${userId}-${organizationId}`],
{
tags: [organizationCache.tag.byId(organizationId)],
}
)();
export const verifyUserRoleAccess = async (
organizationId: string,
userId: string
): Promise<{
hasCreateOrUpdateAccess: boolean;
hasDeleteAccess: boolean;
hasCreateOrUpdateMembersAccess: boolean;
hasDeleteMembersAccess: boolean;
hasBillingAccess: boolean;
}> => {
const accessObject = {
hasCreateOrUpdateAccess: true,
hasDeleteAccess: true,
hasCreateOrUpdateMembersAccess: true,
hasDeleteMembersAccess: true,
hasBillingAccess: true,
};
const currentUserMembership = await getMembershipByUserIdOrganizationId(userId, organizationId);
const { isOwner, isManager } = getAccessFlags(currentUserMembership?.role);
if (!isOwner) {
accessObject.hasCreateOrUpdateAccess = false;
accessObject.hasDeleteAccess = false;
accessObject.hasCreateOrUpdateMembersAccess = false;
accessObject.hasDeleteMembersAccess = false;
accessObject.hasBillingAccess = false;
}
if (isManager) {
accessObject.hasCreateOrUpdateMembersAccess = true;
accessObject.hasDeleteMembersAccess = true;
accessObject.hasBillingAccess = true;
}
return accessObject;
};