completed notifications pruning method

This commit is contained in:
Julian Lam
2013-10-28 14:53:41 -04:00
parent d7651d1504
commit 930a9c8bca
3 changed files with 46 additions and 7 deletions

View File

@@ -7,10 +7,13 @@ var RDB = require('./redis.js'),
RDB.multi()
.hmget('notifications:' + nid, 'text', 'score', 'path', 'datetime', 'uniqueId')
.zrank('uid:' + uid + ':notifications:read', nid)
.exists('notifications:' + nid)
.exec(function(err, results) {
var notification = results[0]
readIdx = results[1];
if (!results[2]) return callback(null);
callback({
nid: nid,
text: notification[0],
@@ -41,6 +44,19 @@ var RDB = require('./redis.js'),
});
});
},
destroy: function(nid) {
var multi = RDB.multi();
multi.del('notifications:' + nid);
multi.srem('notifications', nid);
multi.exec(function(err) {
if (err) {
winston.error('Problem deleting expired notifications. Stack follows.');
winston.error(err.stack);
}
});
},
push: function(nid, uids, callback) {
if (!Array.isArray(uids)) uids = [uids];
@@ -153,15 +169,24 @@ var RDB = require('./redis.js'),
var numInboxes = results.inboxes.length,
x;
async.each(results.nids, function(nid, next) {
async.eachSeries(results.nids, function(nid, next) {
var multi = RDB.multi();
for(x=0;x<numInboxes;x++) {
multi.zscore(inboxKey, results.inboxes[x]);
multi.zscore(results.inboxes[x], nid);
}
multi.exec(function(results) {
multi.exec(function(err, results) {
// If the notification is not present in any inbox, delete it altogether
var expired = results.every(function(present) {
if (present === null) return true;
});
if (expired) {
notifications.destroy(nid);
}
next();
});
}, function(err) {