wildduck/lib/handlers/on-append.js

79 lines
2.8 KiB
JavaScript
Raw Normal View History

'use strict';
2017-11-13 21:27:37 +08:00
const config = require('wild-config');
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) => {
if (err) {
return callback(err);
}
2017-08-03 20:26:44 +08:00
if (!userData) {
return callback(new Error('User not found'));
}
2017-08-03 20:26:44 +08:00
if (userData.quota && userData.storageUsed > userData.quota) {
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-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
});
});
};