wildduck/lib/handlers/on-auth.js

72 lines
2.1 KiB
JavaScript
Raw Normal View History

'use strict';
const config = require('wild-config');
2017-12-08 20:29:00 +08:00
module.exports = (server, userHandler, userCache) => (login, session, callback) => {
let username = (login.username || '').toString().trim();
userHandler.authenticate(
username,
login.password,
2017-07-24 21:44:08 +08:00
'imap',
{
protocol: 'IMAP',
2017-10-30 19:41:53 +08:00
sess: session.id,
ip: session.remoteAddress
},
(err, result) => {
if (err) {
return callback(err);
}
if (!result) {
return callback();
}
2017-07-24 21:44:08 +08:00
if (result.scope === 'master' && result.require2fa) {
// master password not allowed if 2fa is enabled!
return callback();
}
let checkConnectionLimits = next => {
if (typeof server.notifier.allocateConnection === 'function') {
2017-12-08 20:29:00 +08:00
return userCache.get(result.user, 'imapMaxConnections', config.imap.maxConnections || 15, (err, limit) => {
if (err) {
return callback(err);
}
server.notifier.allocateConnection(
{
service: 'imap',
session,
user: result.user,
limit
},
next
);
});
}
return next(null, true);
};
checkConnectionLimits((err, success) => {
if (err) {
return callback(err);
}
if (!success) {
err = new Error('[ALERT] Too many simultaneous connections.');
err.response = 'NO';
return callback(err);
}
callback(null, {
user: {
id: result.user,
username: result.username
}
});
});
}
);
};