mirror of
https://github.com/formbricks/formbricks.git
synced 2026-04-19 11:11:05 -05:00
* Chore: moved profile settings to server component * ran pnpm format * fisxed a build issue * made requested changes * made some refactors --------- Co-authored-by: Matthias Nannt <mail@matthiasnannt.com>
142 lines
3.7 KiB
TypeScript
142 lines
3.7 KiB
TypeScript
import { prisma } from "@formbricks/database";
|
|
import { DatabaseError, ResourceNotFoundError } from "@formbricks/errors";
|
|
import { Prisma } from "@prisma/client";
|
|
import { TProfile } from "@formbricks/types/v1/profile";
|
|
import { deleteTeam } from "./team";
|
|
import { MembershipRole } from "@prisma/client";
|
|
import { cache } from "react";
|
|
|
|
const responseSelection = {
|
|
id: true,
|
|
name: true,
|
|
email: true,
|
|
createdAt: true,
|
|
updatedAt: true,
|
|
};
|
|
|
|
interface Membership {
|
|
role: MembershipRole;
|
|
userId: string;
|
|
}
|
|
|
|
// function to retrive basic information about a user's profile
|
|
export const getProfile = cache(async (userId: string): Promise<TProfile | null> => {
|
|
try {
|
|
const profile = await prisma.user.findUnique({
|
|
where: {
|
|
id: userId,
|
|
},
|
|
select: responseSelection,
|
|
});
|
|
|
|
if (!profile) {
|
|
return null;
|
|
}
|
|
|
|
return profile;
|
|
} catch (error) {
|
|
if (error instanceof Prisma.PrismaClientKnownRequestError) {
|
|
throw new DatabaseError("Database operation failed");
|
|
}
|
|
|
|
throw error;
|
|
}
|
|
});
|
|
|
|
const updateUserMembership = async (teamId: string, userId: string, role: MembershipRole) => {
|
|
await prisma.membership.update({
|
|
where: {
|
|
userId_teamId: {
|
|
userId,
|
|
teamId,
|
|
},
|
|
},
|
|
data: {
|
|
role,
|
|
},
|
|
});
|
|
};
|
|
|
|
const getAdminMemberships = (memberships: Membership[]) =>
|
|
memberships.filter((membership) => membership.role === MembershipRole.admin);
|
|
|
|
// function to update a user's profile
|
|
export const updateProfile = async (personId: string, data: Prisma.UserUpdateInput): Promise<TProfile> => {
|
|
try {
|
|
const updatedProfile = await prisma.user.update({
|
|
where: {
|
|
id: personId,
|
|
},
|
|
data: data,
|
|
});
|
|
|
|
return updatedProfile;
|
|
} catch (error) {
|
|
if (error instanceof Prisma.PrismaClientKnownRequestError && error.code === "P2016") {
|
|
throw new ResourceNotFoundError("Profile", personId);
|
|
} else {
|
|
throw error; // Re-throw any other errors
|
|
}
|
|
}
|
|
};
|
|
const deleteUser = async (userId: string) => {
|
|
await prisma.user.delete({
|
|
where: {
|
|
id: userId,
|
|
},
|
|
});
|
|
};
|
|
|
|
// function to delete a user's profile including teams
|
|
export const deleteProfile = async (personId: string): Promise<void> => {
|
|
try {
|
|
const currentUserMemberships = await prisma.membership.findMany({
|
|
where: {
|
|
userId: personId,
|
|
},
|
|
include: {
|
|
team: {
|
|
select: {
|
|
id: true,
|
|
name: true,
|
|
memberships: {
|
|
select: {
|
|
userId: true,
|
|
role: true,
|
|
},
|
|
},
|
|
},
|
|
},
|
|
},
|
|
});
|
|
|
|
for (const currentUserMembership of currentUserMemberships) {
|
|
const teamMemberships = currentUserMembership.team.memberships;
|
|
const role = currentUserMembership.role;
|
|
const teamId = currentUserMembership.teamId;
|
|
|
|
const teamAdminMemberships = getAdminMemberships(teamMemberships);
|
|
const teamHasAtLeastOneAdmin = teamAdminMemberships.length > 0;
|
|
const teamHasOnlyOneMember = teamMemberships.length === 1;
|
|
const currentUserIsTeamOwner = role === MembershipRole.owner;
|
|
|
|
if (teamHasOnlyOneMember) {
|
|
await deleteTeam(teamId);
|
|
} else if (currentUserIsTeamOwner && teamHasAtLeastOneAdmin) {
|
|
const firstAdmin = teamAdminMemberships[0];
|
|
await updateUserMembership(teamId, firstAdmin.userId, MembershipRole.owner);
|
|
} else if (currentUserIsTeamOwner) {
|
|
await deleteTeam(teamId);
|
|
}
|
|
}
|
|
|
|
await deleteUser(personId);
|
|
} catch (error) {
|
|
if (error instanceof Prisma.PrismaClientKnownRequestError) {
|
|
throw new DatabaseError("Database operation failed");
|
|
}
|
|
|
|
throw error;
|
|
}
|
|
};
|