Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fixed membership request being added in the user's DB #2582

Open
wants to merge 12 commits into
base: develop
Choose a base branch
from
41 changes: 34 additions & 7 deletions src/resolvers/Mutation/sendMembershipRequest.ts
Original file line number Diff line number Diff line change
Expand Up @@ -78,8 +78,15 @@ export const sendMembershipRequest: MutationResolvers["sendMembershipRequest"] =

// Checks if the user is blocked
const user = await User.findById(context.userId).lean();
if (user === null) {
throw new errors.NotFoundError(
requestContext.translate(USER_NOT_FOUND_ERROR.MESSAGE),
USER_NOT_FOUND_ERROR.CODE,
USER_NOT_FOUND_ERROR.PARAM,
);
}
syedali237 marked this conversation as resolved.
Show resolved Hide resolved

if (
user !== null &&
organization.blockedUsers.some((blockedUser) =>
new mongoose.Types.ObjectId(blockedUser.toString()).equals(user._id),
)
Expand All @@ -97,20 +104,37 @@ export const sendMembershipRequest: MutationResolvers["sendMembershipRequest"] =
organization: organization._id,
});

// console.log("Membership request already exists:", membershipRequestExists);

if (membershipRequestExists) {
// Check if the request is already in the user's document
if (!user.membershipRequests.includes(membershipRequestExists._id)) {
// If it's not in the user's document, add it
await User.findByIdAndUpdate(
context.userId,
{
$push: {
membershipRequests: membershipRequestExists._id,
},
},
{ new: true, runValidators: true },
);
}

syedali237 marked this conversation as resolved.
Show resolved Hide resolved
throw new errors.ConflictError(
requestContext.translate(MEMBERSHIP_REQUEST_ALREADY_EXISTS.MESSAGE),
MEMBERSHIP_REQUEST_ALREADY_EXISTS.CODE,
MEMBERSHIP_REQUEST_ALREADY_EXISTS.PARAM,
);
}

// Creating Membership Request
const createdMembershipRequest = await MembershipRequest.create({
user: context.userId,
organization: organization._id,
});

// add membership request to organization
// Updating Membership Request in organization
const updatedOrganization = await Organization.findOneAndUpdate(
{
_id: organization._id,
Expand All @@ -129,17 +153,20 @@ export const sendMembershipRequest: MutationResolvers["sendMembershipRequest"] =
await cacheOrganizations([updatedOrganization]);
}

// add membership request to user
await User.updateOne(
{
_id: context.userId,
},
// Updating User
const updateResult = await User.findByIdAndUpdate(
context.userId,
{
$push: {
membershipRequests: createdMembershipRequest._id,
},
},
{ new: true, runValidators: true },
);

if (!updateResult) {
throw new Error("Failed to update user with membership request");
}

syedali237 marked this conversation as resolved.
Show resolved Hide resolved
return createdMembershipRequest.toObject();
};
Loading