mirror of
https://github.com/danny-avila/LibreChat.git
synced 2025-09-22 08:12:00 +02:00

* chore: RequestExecutor typing * feat: allowed action domains * fix: rename TAgentsEndpoint to TAssistantEndpoint in typedefs * chore: update librechat-data-provider version to 0.7.62
25 lines
829 B
JavaScript
25 lines
829 B
JavaScript
const { isEmailDomainAllowed } = require('~/server/services/domains');
|
|
const { logger } = require('~/config');
|
|
|
|
/**
|
|
* Checks the domain's social login is allowed
|
|
*
|
|
* @async
|
|
* @function
|
|
* @param {Object} req - Express request object.
|
|
* @param {Object} res - Express response object.
|
|
* @param {Function} next - Next middleware function.
|
|
*
|
|
* @returns {Promise<function|Object>} - Returns a Promise which when resolved calls next middleware if the domain's email is allowed
|
|
*/
|
|
const checkDomainAllowed = async (req, res, next = () => {}) => {
|
|
const email = req?.user?.email;
|
|
if (email && !(await isEmailDomainAllowed(email))) {
|
|
logger.error(`[Social Login] [Social Login not allowed] [Email: ${email}]`);
|
|
return res.redirect('/login');
|
|
} else {
|
|
return next();
|
|
}
|
|
};
|
|
|
|
module.exports = checkDomainAllowed;
|