X-Git-Url: https://git.auder.net/?a=blobdiff_plain;f=app.js;h=22c220b92ad1df9a35aa8e29928cd6c060d1b5a4;hb=b57dbd126734b4398861292c611197c6991ed3eb;hp=e32ef39e7d88653bb2b6d55f60e1a2f2f4f13411;hpb=9234226104764b91df9d677fb360ad538b98510c;p=vchess.git diff --git a/app.js b/app.js index e32ef39e..22c220b9 100644 --- a/app.js +++ b/app.js @@ -6,8 +6,6 @@ var logger = require('morgan'); var sassMiddleware = require('node-sass-middleware'); var favicon = require('serve-favicon'); -var router = require('./routes/all'); - var app = express(); app.use(favicon(path.join(__dirname, "public", "images", "favicon", "favicon.ico"))); @@ -27,6 +25,9 @@ else })); } +// Allow layout.pug to select the right vue file: +app.locals.development = (app.get('env') === 'development'); + // view engine setup app.set('views', path.join(__dirname, 'views')); app.set('view engine', 'pug'); @@ -42,7 +43,30 @@ app.use(sassMiddleware({ })); app.use(express.static(path.join(__dirname, 'public'))); -app.use('/', router); +// Before showing any page, check + save credentials +app.use(function(req, res, next) { + req.loggedIn = false; + res.locals.user = { name: "" }; + if (!req.cookies.token) + return next(); + UserModel.getOne("sessionToken", req.cookies.token, function(err, user) { + if (!!user) + { + req.loggedIn = true; + res.locals.user = { + _id: user._id, + name: user.name, + email: user.email, + notify: user.notify, + }; + } + next(); + }); +}); + +// Routing +const routes = require(path.join(__dirname, "routes", "all")); +app.use('/', routes); // catch 404 and forward to error handler app.use(function(req, res, next) {