feat: user/notifications refactor

v1.18.x
Barış Soner Uşaklı 6 years ago
parent f2a6f888fb
commit 580f786095

@ -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);
};

Loading…
Cancel
Save