mirror of
https://github.com/nodemailer/wildduck.git
synced 2025-01-04 07:02:45 +08:00
109 lines
4.2 KiB
JavaScript
109 lines
4.2 KiB
JavaScript
'use strict';
|
|
|
|
const log = require('npmlog');
|
|
const db = require('../db');
|
|
|
|
module.exports = (task, data, options, callback) => {
|
|
let cursor = db.users.collection('users').find({}).project({ _id: true, storageUsed: true });
|
|
|
|
let processNext = () => {
|
|
cursor.next((err, userData) => {
|
|
if (err) {
|
|
log.error('Tasks', 'task=quota id=%s error=%s', task._id, err.message);
|
|
return callback(err);
|
|
}
|
|
|
|
if (!userData) {
|
|
return cursor.close(() => callback(null, true));
|
|
}
|
|
|
|
db.database
|
|
.collection('messages')
|
|
.aggregate([
|
|
{
|
|
$match: {
|
|
user: userData._id
|
|
}
|
|
},
|
|
{
|
|
$group: {
|
|
_id: {
|
|
user: '$user'
|
|
},
|
|
storageUsed: {
|
|
$sum: '$size'
|
|
}
|
|
}
|
|
}
|
|
])
|
|
.toArray((err, storageData) => {
|
|
if (err) {
|
|
log.error('Tasks', 'task=quota id=%s user=%s error=%s', task._id, userData._id, err.message);
|
|
return setTimeout(processNext, 5000);
|
|
}
|
|
|
|
let storageUsed = (storageData && storageData[0] && storageData[0].storageUsed) || 0;
|
|
if (storageUsed === userData.storageUsed) {
|
|
log.info(
|
|
'Tasks',
|
|
'task=quota id=%s user=%s stored=%s calculated=%s updated=%s',
|
|
task._id,
|
|
userData._id,
|
|
userData.storageUsed,
|
|
storageUsed,
|
|
'no'
|
|
);
|
|
return setImmediate(processNext);
|
|
}
|
|
|
|
db.users.collection('users').findOneAndUpdate(
|
|
{
|
|
_id: userData._id
|
|
},
|
|
{
|
|
$set: {
|
|
storageUsed: Number(storageUsed) || 0
|
|
}
|
|
},
|
|
{
|
|
returnDocument: 'before',
|
|
projection: {
|
|
storageUsed: true
|
|
}
|
|
},
|
|
(err, r) => {
|
|
if (err) {
|
|
log.error('Tasks', 'task=quota id=%s user=%s error=%s', task._id, userData._id, err.message);
|
|
return setTimeout(processNext, 5000);
|
|
}
|
|
|
|
if (r && r.value) {
|
|
options.loggelf({
|
|
short_message: '[QUOTA] reset',
|
|
_mail_action: 'quota',
|
|
_user: userData._id,
|
|
_set: Number(storageUsed) || 0,
|
|
_previous_storage_used: r.value.storageUsed,
|
|
_storage_used: Number(storageUsed) || 0,
|
|
_sess: 'task.quota.' + task._id
|
|
});
|
|
}
|
|
|
|
log.info(
|
|
'Tasks',
|
|
'task=quota id=%s user=%s stored=%s calculated=%s updated=%s',
|
|
task._id,
|
|
userData._id,
|
|
userData.storageUsed,
|
|
storageUsed,
|
|
r.lastErrorObject && r.lastErrorObject.updatedExisting ? 'yes' : 'no'
|
|
);
|
|
return setImmediate(processNext);
|
|
}
|
|
);
|
|
});
|
|
});
|
|
};
|
|
|
|
processNext();
|
|
};
|