mirror of
https://github.com/NodeBB/NodeBB.git
synced 2025-11-01 03:26:04 +01:00
closed #1874
This commit is contained in:
@@ -74,7 +74,10 @@ var db = require('./database'),
|
|||||||
}
|
}
|
||||||
|
|
||||||
getMessages([mid], fromuid, touid, true, function(err, messages) {
|
getMessages([mid], fromuid, touid, true, function(err, messages) {
|
||||||
callback(err, messages ? messages[0] : null);
|
Messaging.isNewSet(fromuid, touid, mid, function(err, isNewSet) {
|
||||||
|
messages[0].newSet = isNewSet;
|
||||||
|
callback(err, messages ? messages[0] : null);
|
||||||
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
@@ -166,6 +169,32 @@ var db = require('./database'),
|
|||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Messaging.isNewSet = function(fromuid, touid, mid, callback) {
|
||||||
|
var uids = sortUids(fromuid, touid),
|
||||||
|
setKey = 'messages:uid:' + uids[0] + ':to:' + uids[1];
|
||||||
|
|
||||||
|
async.waterfall([
|
||||||
|
async.apply(db.sortedSetRank, setKey, mid),
|
||||||
|
function(index, next) {
|
||||||
|
if (index > 0) {
|
||||||
|
db.getSortedSetRange(setKey, index-1, index, next);
|
||||||
|
} else {
|
||||||
|
next(null, true);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
function(mids, next) {
|
||||||
|
db.getObjects(['message:' + mids[0], 'message:' + mids[1]], next);
|
||||||
|
},
|
||||||
|
function(messages, next) {
|
||||||
|
if (typeof messages !== 'boolean') {
|
||||||
|
next(null, parseInt(messages[1].timestamp, 10) > parseInt(messages[0].timestamp, 10) + (1000*60*5));
|
||||||
|
} else {
|
||||||
|
next(null, messages);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
], callback);
|
||||||
|
};
|
||||||
|
|
||||||
Messaging.updateChatTime = function(uid, toUid, callback) {
|
Messaging.updateChatTime = function(uid, toUid, callback) {
|
||||||
callback = callback || function() {};
|
callback = callback || function() {};
|
||||||
db.sortedSetAdd('uid:' + uid + ':chats', Date.now(), toUid, callback);
|
db.sortedSetAdd('uid:' + uid + ':chats', Date.now(), toUid, callback);
|
||||||
|
|||||||
Reference in New Issue
Block a user