wildduck/lib/handlers/on-status.js
Andris Reinman 942e35349e v1.14.0
2019-01-23 23:38:29 +02:00

74 lines
2.3 KiB
JavaScript

'use strict';
const db = require('../db');
// STATUS (X Y X)
module.exports = server => (path, session, callback) => {
server.logger.debug(
{
tnx: 'status',
cid: session.id
},
'[%s] Requested status for "%s"',
session.id,
path
);
db.database.collection('mailboxes').findOne(
{
user: session.user.id,
path
},
{
maxTimeMS: 500
},
(err, mailboxData) => {
if (err) {
return callback(err);
}
if (!mailboxData) {
return callback(null, 'NONEXISTENT');
}
db.database
.collection('messages')
.find({
mailbox: mailboxData._id,
// uid is part of the sharding key so we need it somehow represented in the query
uid: {
$gt: 0,
$lt: mailboxData.uidNext
}
})
.maxTimeMS(500)
.count((err, total) => {
if (err) {
return callback(err);
}
db.database
.collection('messages')
.find({
mailbox: mailboxData._id,
unseen: true,
// uid is part of the sharding key so we need it somehow represented in the query
uid: {
$gt: 0,
$lt: mailboxData.uidNext
}
})
.maxTimeMS(500)
.count((err, unseen) => {
if (err) {
return callback(err);
}
return callback(null, {
messages: total,
uidNext: mailboxData.uidNext,
uidValidity: mailboxData.uidValidity,
unseen
});
});
});
}
);
};