wildduck/lib/handlers/on-status.js

71 lines
2.1 KiB
JavaScript
Raw Normal View History

'use strict';
const db = require('../db');
const consts = require('../consts');
// 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
},
2019-01-24 05:38:29 +08:00
{
maxTimeMS: consts.DB_MAX_TIME_MAILBOXES
2019-01-24 05:38:29 +08:00
},
(err, mailboxData) => {
if (err) {
return callback(err);
}
if (!mailboxData) {
return callback(null, 'NONEXISTENT');
}
2019-05-08 21:30:57 +08:00
db.database.collection('messages').countDocuments(
{
2019-05-08 20:04:16 +08:00
mailbox: mailboxData._id
2019-05-08 21:30:57 +08:00
},
{
maxTimeMS: consts.DB_MAX_TIME_MESSAGES
},
(err, total) => {
if (err) {
return callback(err);
}
2019-05-08 21:30:57 +08:00
db.database.collection('messages').countDocuments(
{
mailbox: mailboxData._id,
2019-05-08 20:04:16 +08:00
unseen: true
2019-05-08 21:30:57 +08:00
},
{
maxTimeMS: consts.DB_MAX_TIME_MESSAGES
},
(err, unseen) => {
if (err) {
return callback(err);
}
return callback(null, {
messages: total,
uidNext: mailboxData.uidNext,
uidValidity: mailboxData.uidValidity,
unseen,
highestModseq: Number(mailboxData.modifyIndex) || 0
});
2019-05-08 21:30:57 +08:00
}
);
}
);
}
);
};