2017-07-16 00:08:33 +08:00
|
|
|
'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
|
|
|
|
);
|
2017-12-10 07:19:50 +08:00
|
|
|
db.database.collection('mailboxes').findOne(
|
|
|
|
{
|
|
|
|
user: session.user.id,
|
|
|
|
path
|
|
|
|
},
|
|
|
|
(err, mailboxData) => {
|
|
|
|
if (err) {
|
|
|
|
return callback(err);
|
|
|
|
}
|
|
|
|
if (!mailboxData) {
|
|
|
|
return callback(null, 'NONEXISTENT');
|
|
|
|
}
|
2017-07-16 00:08:33 +08:00
|
|
|
|
2017-12-10 07:19:50 +08:00
|
|
|
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
|
|
|
|
}
|
|
|
|
})
|
|
|
|
.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
|
|
|
|
}
|
|
|
|
})
|
|
|
|
.count((err, unseen) => {
|
|
|
|
if (err) {
|
|
|
|
return callback(err);
|
|
|
|
}
|
2017-07-16 00:08:33 +08:00
|
|
|
|
2017-12-10 07:19:50 +08:00
|
|
|
return callback(null, {
|
|
|
|
messages: total,
|
|
|
|
uidNext: mailboxData.uidNext,
|
|
|
|
uidValidity: mailboxData.uidValidity,
|
|
|
|
unseen
|
|
|
|
});
|
2017-07-16 00:08:33 +08:00
|
|
|
});
|
2017-12-10 07:19:50 +08:00
|
|
|
});
|
|
|
|
}
|
|
|
|
);
|
2017-07-16 00:08:33 +08:00
|
|
|
};
|