mirror of
https://github.com/NodeBB/NodeBB.git
synced 2026-01-01 21:30:30 +01:00
feat: user/notifications refactor
This commit is contained in:
@@ -3,6 +3,7 @@
|
||||
|
||||
var async = require('async');
|
||||
var winston = require('winston');
|
||||
var _ = require('lodash');
|
||||
|
||||
var db = require('../database');
|
||||
var meta = require('../meta');
|
||||
@@ -45,17 +46,11 @@ function filterNotifications(nids, filter, callback) {
|
||||
}
|
||||
async.waterfall([
|
||||
function (next) {
|
||||
var keys = nids.map(function (nid) {
|
||||
return 'notifications:' + nid;
|
||||
});
|
||||
const keys = nids.map(nid => 'notifications:' + nid);
|
||||
db.getObjectsFields(keys, ['nid', 'type'], next);
|
||||
},
|
||||
function (notifications, next) {
|
||||
nids = notifications.filter(function (notification) {
|
||||
return notification && notification.nid && notification.type === filter;
|
||||
}).map(function (notification) {
|
||||
return notification.nid;
|
||||
});
|
||||
nids = notifications.filter(n => n && n.nid && n.type === filter).map(n => n.nid);
|
||||
next(null, nids);
|
||||
},
|
||||
], callback);
|
||||
@@ -65,17 +60,13 @@ UserNotifications.getAll = function (uid, filter, callback) {
|
||||
var nids;
|
||||
async.waterfall([
|
||||
function (next) {
|
||||
async.parallel({
|
||||
unread: function (next) {
|
||||
db.getSortedSetRevRange('uid:' + uid + ':notifications:unread', 0, -1, next);
|
||||
},
|
||||
read: function (next) {
|
||||
db.getSortedSetRevRange('uid:' + uid + ':notifications:read', 0, -1, next);
|
||||
},
|
||||
}, next);
|
||||
db.getSortedSetRevRange([
|
||||
'uid:' + uid + ':notifications:unread',
|
||||
'uid:' + uid + ':notifications:read',
|
||||
], 0, -1, next);
|
||||
},
|
||||
function (results, next) {
|
||||
nids = results.unread.concat(results.read);
|
||||
function (_nids, next) {
|
||||
nids = _.uniq(_nids);
|
||||
db.isSortedSetMembers('notifications', nids, next);
|
||||
},
|
||||
function (exists, next) {
|
||||
@@ -183,17 +174,12 @@ UserNotifications.getUnreadCount = function (uid, callback) {
|
||||
notifications.filterExists(nids, next);
|
||||
},
|
||||
function (nids, next) {
|
||||
var keys = nids.map(function (nid) {
|
||||
return 'notifications:' + nid;
|
||||
});
|
||||
|
||||
const keys = nids.map(nid => 'notifications:' + nid);
|
||||
db.getObjectsFields(keys, ['mergeId'], next);
|
||||
},
|
||||
function (mergeIds, next) {
|
||||
// Collapse any notifications with identical mergeIds
|
||||
mergeIds = mergeIds.map(function (set) {
|
||||
return set.mergeId;
|
||||
});
|
||||
mergeIds = mergeIds.map(set => set.mergeId);
|
||||
|
||||
next(null, mergeIds.reduce(function (count, mergeId, idx, arr) {
|
||||
// A missing (null) mergeId means that notification is counted separately.
|
||||
@@ -219,15 +205,12 @@ UserNotifications.getUnreadByField = function (uid, field, values, callback) {
|
||||
return callback(null, []);
|
||||
}
|
||||
|
||||
var keys = nids.map(nid => 'notifications:' + nid);
|
||||
const keys = nids.map(nid => 'notifications:' + nid);
|
||||
db.getObjectsFields(keys, ['nid', field], next);
|
||||
},
|
||||
function (notifications, next) {
|
||||
const valuesSet = new Set(values.map(value => String(value)));
|
||||
nids = notifications.filter(function (notification) {
|
||||
return notification && notification[field] && valuesSet.has(String(notification[field]));
|
||||
}).map(notification => notification.nid);
|
||||
|
||||
nids = notifications.filter(n => n && n[field] && valuesSet.has(String(n[field]))).map(n => n.nid);
|
||||
next(null, nids);
|
||||
},
|
||||
], callback);
|
||||
@@ -237,13 +220,9 @@ UserNotifications.deleteAll = function (uid, callback) {
|
||||
if (parseInt(uid, 10) <= 0) {
|
||||
return setImmediate(callback);
|
||||
}
|
||||
async.parallel([
|
||||
function (next) {
|
||||
db.delete('uid:' + uid + ':notifications:unread', next);
|
||||
},
|
||||
function (next) {
|
||||
db.delete('uid:' + uid + ':notifications:read', next);
|
||||
},
|
||||
db.deleteAll([
|
||||
'uid:' + uid + ':notifications:unread',
|
||||
'uid:' + uid + ':notifications:read',
|
||||
], callback);
|
||||
};
|
||||
|
||||
|
||||
Reference in New Issue
Block a user