mirror of
https://github.com/NodeBB/NodeBB.git
synced 2025-10-26 08:36:12 +01:00
fix: #7762, allow array for isBanned
dont filter banned users one by one in digest
This commit is contained in:
@@ -1,6 +1,5 @@
|
||||
'use strict';
|
||||
|
||||
const util = require('util');
|
||||
const db = require('../database');
|
||||
|
||||
module.exports = function (User) {
|
||||
@@ -42,42 +41,45 @@ module.exports = function (User) {
|
||||
return banData;
|
||||
};
|
||||
|
||||
User.bans.unban = async function (uid) {
|
||||
await User.setUserFields(uid, { banned: 0, 'banned:expire': 0 });
|
||||
await db.sortedSetsRemove(['users:banned', 'users:banned:expire'], uid);
|
||||
User.bans.unban = async function (uids) {
|
||||
if (Array.isArray(uids)) {
|
||||
await db.setObject(uids.map(uid => 'user:' + uid), { banned: 0, 'banned:expire': 0 });
|
||||
} else {
|
||||
await User.setUserFields(uids, { banned: 0, 'banned:expire': 0 });
|
||||
}
|
||||
|
||||
await db.sortedSetRemove(['users:banned', 'users:banned:expire'], uids);
|
||||
};
|
||||
|
||||
User.bans.getBannedAndExpired = async function (uid) {
|
||||
if (parseInt(uid, 10) <= 0) {
|
||||
return false;
|
||||
}
|
||||
const userData = await User.getUserFields(uid, ['banned', 'banned:expire']);
|
||||
User.bans.isBanned = async function (uids) {
|
||||
const isArray = Array.isArray(uids);
|
||||
uids = isArray ? uids : [uids];
|
||||
const result = await User.bans.unbanIfExpired(uids);
|
||||
return isArray ? result.map(r => r.banned) : result[0].banned;
|
||||
};
|
||||
|
||||
User.bans.unbanIfExpired = async function (uids) {
|
||||
// loading user data will unban if it has expired -barisu
|
||||
const userData = await User.getUsersFields(uids, ['banned', 'banned:expire']);
|
||||
return User.bans.calcExpiredFromUserData(userData);
|
||||
};
|
||||
|
||||
User.bans.calcExpiredFromUserData = function (userData) {
|
||||
return {
|
||||
banned: !!userData.banned,
|
||||
'banned:expire': userData['banned:expire'],
|
||||
banExpired: userData['banned:expire'] <= Date.now() && userData['banned:expire'] !== 0,
|
||||
};
|
||||
const isArray = Array.isArray(userData);
|
||||
userData = isArray ? userData : [userData];
|
||||
userData = userData.map(function (userData) {
|
||||
return {
|
||||
banned: userData && !!userData.banned,
|
||||
'banned:expire': userData && userData['banned:expire'],
|
||||
banExpired: userData && userData['banned:expire'] <= Date.now() && userData['banned:expire'] !== 0,
|
||||
};
|
||||
});
|
||||
return isArray ? userData : userData[0];
|
||||
};
|
||||
|
||||
User.bans.unbanIfExpired = async function (uid) {
|
||||
const result = await User.bans.getBannedAndExpired(uid);
|
||||
if (result.banned && result.banExpired) {
|
||||
await User.bans.unban(uid);
|
||||
return { banned: false, banExpired: true, 'banned:expire': 0 };
|
||||
}
|
||||
return result;
|
||||
};
|
||||
|
||||
User.bans.isBanned = async function (uid) {
|
||||
if (parseInt(uid, 10) <= 0) {
|
||||
return false;
|
||||
}
|
||||
const result = await User.bans.unbanIfExpired(uid);
|
||||
return result.banned;
|
||||
User.bans.filterBanned = async function (uids) {
|
||||
const isBanned = User.bans.isBanned(uids);
|
||||
return uids.filter((uid, index) => !isBanned[index]);
|
||||
};
|
||||
|
||||
User.bans.getReason = async function (uid) {
|
||||
@@ -91,14 +93,4 @@ module.exports = function (User) {
|
||||
const banObj = await db.getObject(keys[0]);
|
||||
return banObj && banObj.reason ? banObj.reason : '';
|
||||
};
|
||||
|
||||
// TODO Remove in v1.13.0
|
||||
const deprecatedMessage = (oldPath, newPath) => `function ${oldPath} is deprecated, please use ${newPath} instead`;
|
||||
User.ban = util.deprecate(User.bans.ban, deprecatedMessage('User.ban', 'User.bans.ban'));
|
||||
User.unban = util.deprecate(User.bans.unban, deprecatedMessage('User.unban', 'User.bans.unban'));
|
||||
User.getBannedAndExpired = util.deprecate(User.bans.getBannedAndExpired, deprecatedMessage('User.getBannedAndExpired', 'User.bans.getBannedAndExpired'));
|
||||
User.calcBanExpiredFromUserData = util.deprecate(User.bans.calcExpiredFromUserData, deprecatedMessage('User.calcBanExpiredFromUserData', 'User.bans.calcExpiredFromUserData'));
|
||||
User.unbanIfBanExpired = util.deprecate(User.bans.unbanIfExpired, deprecatedMessage('User.unbanIfBanExpired', 'User.bans.unbanIfExpired'));
|
||||
User.isBanned = util.deprecate(User.bans.isBanned, deprecatedMessage('User.isBanned', 'User.bans.isBanned'));
|
||||
User.getBannedReason = util.deprecate(User.bans.getReason, deprecatedMessage('User.getBannedReason', 'User.bans.getReason'));
|
||||
};
|
||||
|
||||
@@ -65,11 +65,16 @@ Digest.getSubscribers = function (interval, callback) {
|
||||
user.getMultipleUserSettings(uids, next);
|
||||
},
|
||||
function (settings, next) {
|
||||
const subUids = [];
|
||||
settings.forEach(function (hash) {
|
||||
if (hash.dailyDigestFreq === interval) {
|
||||
subs.push(hash.uid);
|
||||
subUids.push(hash.uid);
|
||||
}
|
||||
});
|
||||
user.bans.filterBanned(subUids, next);
|
||||
},
|
||||
function (uids, next) {
|
||||
subs = subs.concat(uids);
|
||||
next();
|
||||
},
|
||||
], next);
|
||||
@@ -77,13 +82,6 @@ Digest.getSubscribers = function (interval, callback) {
|
||||
next(err, subs);
|
||||
});
|
||||
},
|
||||
function (subscribers, next) {
|
||||
async.filter(subscribers, function (uid, next) {
|
||||
user.bans.isBanned(uid, function (err, banned) {
|
||||
next(err, !banned);
|
||||
});
|
||||
}, next);
|
||||
},
|
||||
function (subscribers, next) {
|
||||
plugins.fireHook('filter:digest.subscribers', {
|
||||
interval: interval,
|
||||
|
||||
Reference in New Issue
Block a user