mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-12-18 07:07:35 +01:00
fix(challenge): don't pierce privacy on GET/:id
This commit is contained in:
@@ -575,7 +575,7 @@ api.getChallenge = {
|
||||
|
||||
// Fetching basic group data
|
||||
const group = await Group.getGroup({
|
||||
user, groupId: challenge.group, fields: `${basicGroupFields} purchased`, optionalMembership: true,
|
||||
user, groupId: challenge.group, fields: `${basicGroupFields} purchased`,
|
||||
});
|
||||
if (!group && !challenge.canView(user, group)) throw new NotFound(res.t('challengeNotFound'));
|
||||
const chalRes = challenge.toJSON();
|
||||
|
||||
@@ -93,6 +93,7 @@ schema.methods.canModify = function canModifyChallenge (user) {
|
||||
schema.methods.canJoin = function canJoinChallenge (user, group) {
|
||||
// for when leader has left private group that contains the challenge
|
||||
if (this.isLeader(user)) return true;
|
||||
if (!group) return false;
|
||||
if (group.type === 'guild' && group.privacy === 'public') {
|
||||
return group._id === TAVERN_ID;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user