mirror of
https://github.com/danny-avila/LibreChat.git
synced 2025-12-18 09:20:15 +01:00
* ci(backend-review.yml): add linter step to the backend review workflow * chore(backend-review.yml): remove prettier from lint-action configuration * chore: apply new linting workflow * chore(lint-staged.config.js): reorder lint-staged tasks for JavaScript and TypeScript files * chore(eslint): update ignorePatterns in .eslintrc.js chore(lint-action): remove prettier option in backend-review.yml chore(package.json): add lint and lint:fix scripts * chore(lint-staged.config.js): remove prettier --write command for js, jsx, ts, tsx files * chore(titleConvo.js): remove unnecessary console.log statement chore(titleConvo.js): add missing comma in options object * chore: apply linting to all files * chore(lint-staged.config.js): update lint-staged configuration to include prettier formatting
66 lines
1.9 KiB
JavaScript
66 lines
1.9 KiB
JavaScript
const passport = require('passport');
|
|
const PassportLocalStrategy = require('passport-local').Strategy;
|
|
|
|
const User = require('../models/User');
|
|
const { loginSchema } = require('./validators');
|
|
const DebugControl = require('../utils/debug.js');
|
|
|
|
const passportLogin = new PassportLocalStrategy(
|
|
{
|
|
usernameField: 'email',
|
|
passwordField: 'password',
|
|
session: false,
|
|
passReqToCallback: true,
|
|
},
|
|
async (req, email, password, done) => {
|
|
const { error } = loginSchema.validate(req.body);
|
|
if (error) {
|
|
log({
|
|
title: 'Passport Local Strategy - Validation Error',
|
|
parameters: [{ name: 'req.body', value: req.body }],
|
|
});
|
|
return done(null, false, { message: error.details[0].message });
|
|
}
|
|
|
|
try {
|
|
const user = await User.findOne({ email: email.trim() });
|
|
if (!user) {
|
|
log({
|
|
title: 'Passport Local Strategy - User Not Found',
|
|
parameters: [{ name: 'email', value: email }],
|
|
});
|
|
return done(null, false, { message: 'Email does not exists.' });
|
|
}
|
|
|
|
user.comparePassword(password, function (err, isMatch) {
|
|
if (err) {
|
|
log({
|
|
title: 'Passport Local Strategy - Compare password error',
|
|
parameters: [{ name: 'error', value: err }],
|
|
});
|
|
return done(err);
|
|
}
|
|
if (!isMatch) {
|
|
log({
|
|
title: 'Passport Local Strategy - Password does not match',
|
|
parameters: [{ name: 'isMatch', value: isMatch }],
|
|
});
|
|
return done(null, false, { message: 'Incorrect password.' });
|
|
}
|
|
|
|
return done(null, user);
|
|
});
|
|
} catch (err) {
|
|
return done(err);
|
|
}
|
|
},
|
|
);
|
|
|
|
passport.use(passportLogin);
|
|
|
|
function log({ title, parameters }) {
|
|
DebugControl.log.functionName(title);
|
|
if (parameters) {
|
|
DebugControl.log.parameters(parameters);
|
|
}
|
|
}
|