christmas/index.js

74 lines
2 KiB
JavaScript
Raw Normal View History

2018-11-22 15:42:19 -08:00
const expressSessionLevel = require('express-session-level');
2018-11-20 11:19:58 -08:00
const LocalStrategy = require('passport-local').Strategy;
2018-11-22 15:42:19 -08:00
const session = require('express-session');
2018-11-20 11:19:58 -08:00
const bcrypt = require('bcrypt-nodejs');
const flash = require('connect-flash');
const passport = require('passport');
const express = require('express');
const PouchDB = require('pouchdb');
2018-11-22 15:42:19 -08:00
const level = require('level');
2018-11-20 11:19:58 -08:00
const config = require('./config');
const logger = require('./logger');
const app = express();
const db = new PouchDB(config.dbUrl);
passport.use('local', new LocalStrategy(
(username, password, done) => {
2018-12-03 14:03:43 -08:00
username = username.trim();
2018-11-20 11:19:58 -08:00
db.get(username)
.then(doc => {
bcrypt.compare(password, doc.password, (err, correct) => {
if (err) return done(err);
if (!correct) return done(null, false, { message: 'Incorrect password' });
if (correct) return done(null, doc);
});
})
.catch(err => {
if (err.message === 'missing') return done(null, false, { message: 'Incorrect username.' });
return done(err);
});
}
));
passport.serializeUser((user, callback) => callback(null, user._id));
passport.deserializeUser((user, callback) => {
db.get(user)
.then(dbUser => callback(null, dbUser))
.catch(err => callback(err));
});
2018-11-22 15:42:19 -08:00
const LevelStore = expressSessionLevel(session);
2019-08-19 07:49:21 -07:00
const sessionDb = level(config.sessionStore)
2018-11-22 15:42:19 -08:00
2018-11-20 11:19:58 -08:00
app.use(require('body-parser').urlencoded({ extended: true }));
2018-11-22 15:42:19 -08:00
app.use(session({
secret: config.secret,
resave: false,
saveUninitialized: true,
2018-11-22 16:07:42 -08:00
store: new LevelStore(sessionDb),
cookie: {
maxAge: config.sessionMaxAge
}
2018-11-22 15:42:19 -08:00
}));
2018-11-20 11:19:58 -08:00
app.use(flash());
app.use(passport.initialize());
app.use(passport.session());
app.use(require('./middlewares/locals'));
app.use((req, res, next) => {
logger.log('express', `${req.ip} - ${req.method} ${req.originalUrl}`);
next();
});
app.set('view engine', 'pug');
app.use('/', require('./routes')(db));
app.listen(config.port, () => logger.success('express', `Express server started on port ${config.port}!`))