mirror of
https://github.com/Mintplex-Labs/anything-llm.git
synced 2024-11-19 12:40:09 +01:00
2c9cb28d5f
* Simple SSO feature for login flows from external services * linting
40 lines
1.1 KiB
JavaScript
40 lines
1.1 KiB
JavaScript
const { SystemSettings } = require("../../models/systemSettings");
|
|
|
|
/**
|
|
* Checks if simple SSO is enabled for issuance of temporary auth tokens.
|
|
* Note: This middleware must be called after `validApiKey`.
|
|
* @param {import("express").Request} request
|
|
* @param {import("express").Response} response
|
|
* @param {import("express").NextFunction} next
|
|
* @returns {void}
|
|
*/
|
|
async function simpleSSOEnabled(_, response, next) {
|
|
if (!("SIMPLE_SSO_ENABLED" in process.env)) {
|
|
return response
|
|
.status(403)
|
|
.send(
|
|
"Simple SSO is not enabled. It must be enabled to validate or issue temporary auth tokens."
|
|
);
|
|
}
|
|
|
|
// If the multi-user mode response local is not set, we need to check if it's enabled.
|
|
if (!("multiUserMode" in response.locals)) {
|
|
const multiUserMode = await SystemSettings.isMultiUserMode();
|
|
response.locals.multiUserMode = multiUserMode;
|
|
}
|
|
|
|
if (!response.locals.multiUserMode) {
|
|
return response
|
|
.status(403)
|
|
.send(
|
|
"Multi-User mode is not enabled. It must be enabled to use Simple SSO."
|
|
);
|
|
}
|
|
|
|
next();
|
|
}
|
|
|
|
module.exports = {
|
|
simpleSSOEnabled,
|
|
};
|