mirror of
https://github.com/danny-avila/LibreChat.git
synced 2025-12-16 16:30:15 +01:00
* 🧹 chore: Update logger imports to use @librechat/data-schemas across multiple files and remove unused sleep function from queue.js (#9930) * chore: Replace local isEnabled utility with @librechat/api import across multiple files, update test files * chore: Replace local logger import with @librechat/data-schemas logger in countTokens.js and fork.js * chore: Update logs volume path in docker-compose.yml to correct directory * chore: import order of isEnabled in static.js
25 lines
858 B
JavaScript
25 lines
858 B
JavaScript
const cookies = require('cookie');
|
|
const passport = require('passport');
|
|
const { isEnabled } = require('@librechat/api');
|
|
|
|
// This middleware does not require authentication,
|
|
// but if the user is authenticated, it will set the user object.
|
|
const optionalJwtAuth = (req, res, next) => {
|
|
const cookieHeader = req.headers.cookie;
|
|
const tokenProvider = cookieHeader ? cookies.parse(cookieHeader).token_provider : null;
|
|
const callback = (err, user) => {
|
|
if (err) {
|
|
return next(err);
|
|
}
|
|
if (user) {
|
|
req.user = user;
|
|
}
|
|
next();
|
|
};
|
|
if (tokenProvider === 'openid' && isEnabled(process.env.OPENID_REUSE_TOKENS)) {
|
|
return passport.authenticate('openidJwt', { session: false }, callback)(req, res, next);
|
|
}
|
|
passport.authenticate('jwt', { session: false }, callback)(req, res, next);
|
|
};
|
|
|
|
module.exports = optionalJwtAuth;
|