2017-07-16 00:08:33 +08:00
|
|
|
'use strict';
|
|
|
|
|
|
|
|
const db = require('../db');
|
|
|
|
|
|
|
|
// SELECT/EXAMINE
|
|
|
|
module.exports = server => (path, session, callback) => {
|
|
|
|
server.logger.debug(
|
|
|
|
{
|
|
|
|
tnx: 'open',
|
|
|
|
cid: session.id
|
|
|
|
},
|
|
|
|
'[%s] Opening "%s"',
|
|
|
|
session.id,
|
|
|
|
path
|
|
|
|
);
|
2017-12-10 07:19:50 +08:00
|
|
|
db.database.collection('mailboxes').findOne(
|
|
|
|
{
|
|
|
|
user: session.user.id,
|
|
|
|
path
|
|
|
|
},
|
|
|
|
(err, mailbox) => {
|
|
|
|
if (err) {
|
|
|
|
return callback(err);
|
|
|
|
}
|
|
|
|
if (!mailbox) {
|
|
|
|
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: mailbox._id
|
|
|
|
})
|
|
|
|
.project({
|
|
|
|
uid: true
|
|
|
|
})
|
2018-01-04 15:44:21 +08:00
|
|
|
.sort([['uid', 1]])
|
2017-12-10 07:19:50 +08:00
|
|
|
.toArray((err, messages) => {
|
|
|
|
if (err) {
|
|
|
|
return callback(err);
|
|
|
|
}
|
|
|
|
mailbox.uidList = messages.map(message => message.uid).sort((a, b) => a.uid - b.uid);
|
|
|
|
callback(null, mailbox);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
);
|
2017-07-16 00:08:33 +08:00
|
|
|
};
|