Ensured user is saved after validation checks (#9569)

This commit is contained in:
Keith Holliday
2017-11-23 20:46:02 -06:00
committed by GitHub
parent e628c5dc3b
commit 9ef7c45241

View File

@@ -177,9 +177,6 @@ api.acceptQuest = {
let validationErrors = req.validationErrors(); let validationErrors = req.validationErrors();
if (validationErrors) throw validationErrors; if (validationErrors) throw validationErrors;
user.party.quest.RSVPNeeded = false;
await user.save();
let group = await Group.getGroup({user, groupId: req.params.groupId, fields: 'type quest chat'}); let group = await Group.getGroup({user, groupId: req.params.groupId, fields: 'type quest chat'});
if (!group) throw new NotFound(res.t('groupNotFound')); if (!group) throw new NotFound(res.t('groupNotFound'));
@@ -188,6 +185,9 @@ api.acceptQuest = {
if (group.quest.active) throw new NotAuthorized(res.t('questAlreadyUnderway')); if (group.quest.active) throw new NotAuthorized(res.t('questAlreadyUnderway'));
if (group.quest.members[user._id]) throw new BadRequest(res.t('questAlreadyAccepted')); if (group.quest.members[user._id]) throw new BadRequest(res.t('questAlreadyAccepted'));
user.party.quest.RSVPNeeded = false;
await user.save();
group.markModified('quest'); group.markModified('quest');
group.quest.members[user._id] = true; group.quest.members[user._id] = true;
@@ -236,10 +236,6 @@ api.rejectQuest = {
let validationErrors = req.validationErrors(); let validationErrors = req.validationErrors();
if (validationErrors) throw validationErrors; if (validationErrors) throw validationErrors;
user.party.quest = Group.cleanQuestProgress();
user.markModified('party.quest');
await user.save();
let group = await Group.getGroup({user, groupId: req.params.groupId, fields: 'type quest chat'}); let group = await Group.getGroup({user, groupId: req.params.groupId, fields: 'type quest chat'});
if (!group) throw new NotFound(res.t('groupNotFound')); if (!group) throw new NotFound(res.t('groupNotFound'));
if (group.type !== 'party') throw new NotAuthorized(res.t('guildQuestsNotSupported')); if (group.type !== 'party') throw new NotAuthorized(res.t('guildQuestsNotSupported'));
@@ -248,6 +244,10 @@ api.rejectQuest = {
if (group.quest.members[user._id]) throw new BadRequest(res.t('questAlreadyAccepted')); if (group.quest.members[user._id]) throw new BadRequest(res.t('questAlreadyAccepted'));
if (group.quest.members[user._id] === false) throw new BadRequest(res.t('questAlreadyRejected')); if (group.quest.members[user._id] === false) throw new BadRequest(res.t('questAlreadyRejected'));
user.party.quest = Group.cleanQuestProgress();
user.markModified('party.quest');
await user.save();
group.quest.members[user._id] = false; group.quest.members[user._id] = false;
group.markModified('quest.members'); group.markModified('quest.members');