2017-07-16 00:08:33 +08:00
|
|
|
'use strict';
|
|
|
|
|
2017-11-13 21:27:37 +08:00
|
|
|
const config = require('wild-config');
|
2017-07-16 00:08:33 +08:00
|
|
|
const db = require('../db');
|
|
|
|
|
|
|
|
// APPEND mailbox (flags) date message
|
|
|
|
module.exports = (server, messageHandler) => (path, flags, date, raw, session, callback) => {
|
|
|
|
server.logger.debug(
|
|
|
|
{
|
|
|
|
tnx: 'append',
|
|
|
|
cid: session.id
|
|
|
|
},
|
|
|
|
'[%s] Appending message to "%s"',
|
|
|
|
session.id,
|
|
|
|
path
|
|
|
|
);
|
|
|
|
|
|
|
|
db.users.collection('users').findOne({
|
|
|
|
_id: session.user.id
|
2017-08-03 20:26:44 +08:00
|
|
|
}, (err, userData) => {
|
2017-07-16 00:08:33 +08:00
|
|
|
if (err) {
|
|
|
|
return callback(err);
|
|
|
|
}
|
2017-08-03 20:26:44 +08:00
|
|
|
if (!userData) {
|
2017-07-16 00:08:33 +08:00
|
|
|
return callback(new Error('User not found'));
|
|
|
|
}
|
|
|
|
|
2017-08-03 20:26:44 +08:00
|
|
|
if (userData.quota && userData.storageUsed > userData.quota) {
|
2017-07-16 00:08:33 +08:00
|
|
|
return callback(false, 'OVERQUOTA');
|
|
|
|
}
|
2017-11-13 21:27:37 +08:00
|
|
|
|
|
|
|
messageHandler.counters.ttlcounter('iup:' + session.user.id, 0, config.imap.maxUploadMB * 1024 * 1024, false, (err, res) => {
|
|
|
|
if (err) {
|
|
|
|
return callback(err);
|
2017-08-03 20:26:44 +08:00
|
|
|
}
|
2017-11-13 21:27:37 +08:00
|
|
|
if (!res.success) {
|
|
|
|
let err = new Error('Upload was rate limited. Try again in ' + res.ttl + ' seconds');
|
|
|
|
err.response = 'NO';
|
|
|
|
return callback(err);
|
|
|
|
}
|
|
|
|
|
|
|
|
messageHandler.counters.ttlcounter('iup:' + session.user.id, raw.length, config.imap.maxUploadMB * 1024 * 1024, false, () => {
|
|
|
|
messageHandler.encryptMessage(userData.encryptMessages ? userData.pubKey : false, raw, (err, encrypted) => {
|
|
|
|
if (!err && encrypted) {
|
|
|
|
raw = encrypted;
|
2017-07-16 00:08:33 +08:00
|
|
|
}
|
2017-11-13 21:27:37 +08:00
|
|
|
messageHandler.add(
|
|
|
|
{
|
|
|
|
user: session.user.id,
|
|
|
|
path,
|
|
|
|
meta: {
|
|
|
|
source: 'IMAP',
|
|
|
|
from: '',
|
|
|
|
to: [session.user.address || session.user.username],
|
|
|
|
origin: session.remoteAddress,
|
|
|
|
transtype: 'APPEND',
|
|
|
|
time: new Date()
|
|
|
|
},
|
|
|
|
session,
|
|
|
|
date,
|
|
|
|
flags,
|
|
|
|
raw
|
|
|
|
},
|
|
|
|
(err, status, data) => {
|
|
|
|
if (err) {
|
|
|
|
if (err.imapResponse) {
|
|
|
|
return callback(null, err.imapResponse);
|
|
|
|
}
|
|
|
|
return callback(err);
|
|
|
|
}
|
|
|
|
callback(null, status, data);
|
|
|
|
}
|
|
|
|
);
|
|
|
|
});
|
|
|
|
});
|
2017-08-03 20:26:44 +08:00
|
|
|
});
|
2017-07-16 00:08:33 +08:00
|
|
|
});
|
|
|
|
};
|