Commit dcb20866 by Johannes

Implement local file auth

1 parent 5a242369
Showing with 13 additions and 4 deletions
'use strict'; 'use strict';
var passport = require('passport'), var passport = require('passport'),
path = require('path'),
safe = require('safetydance'),
bcrypt = require('bcryptjs'),
LdapStrategy = require('passport-ldapjs').Strategy; LdapStrategy = require('passport-ldapjs').Strategy;
var LOCAL_AUTH_FILE = path.resolve(process.env.LOCAL_AUTH_FILE || './.users.json');
passport.serializeUser(function (user, done) { passport.serializeUser(function (user, done) {
console.log('serializeUser', user); console.log('serializeUser', user);
done(null, user.uid); done(null, user.uid);
...@@ -21,13 +26,17 @@ if (LDAP_URL && LDAP_USERS_BASE_DN) { ...@@ -21,13 +26,17 @@ if (LDAP_URL && LDAP_USERS_BASE_DN) {
exports.ldap = passport.authenticate('ldap'); exports.ldap = passport.authenticate('ldap');
} else { } else {
exports.ldap = function (req, res, next) { console.log('Use local user file:', LOCAL_AUTH_FILE);
console.log('Disable ldap auth, use developer credentials!');
if (req.query.username !== 'test') return res.send(401); exports.ldap = function (req, res, next) {
if (req.query.password !== 'test') return res.send(401); var users = safe.JSON.parse(safe.fs.readFileSync(LOCAL_AUTH_FILE));
if (!users) return res.send(401);
if (!users[req.query.username]) return res.send(401);
bcrypt.compare(req.query.password, users[req.query.username].passwordHash, function (error, valid) {
if (error || !valid) return res.send(401);
next(); next();
});
}; };
} }
......
Markdown is supported
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!