X-Git-Url: https://git.auder.net/?a=blobdiff_plain;f=app.js;h=e63aca44b7ec0f35954d6e4106d25a300733e537;hb=26b8e4f7c71030d49e44fe1d89632ef91b886d67;hp=b44be79104e214aa45a2df1273cebfb1189ad331;hpb=fb1ecbdf0326d659c7afab9c55f8c1031f85b1b9;p=vchess.git diff --git a/app.js b/app.js index b44be791..e63aca44 100644 --- a/app.js +++ b/app.js @@ -5,8 +5,7 @@ var cookieParser = require('cookie-parser'); var logger = require('morgan'); var sassMiddleware = require('node-sass-middleware'); var favicon = require('serve-favicon'); - -var router = require('./routes/all'); +var UserModel = require(path.join(__dirname, "models", "User")); var app = express(); @@ -28,7 +27,7 @@ else } // Allow layout.pug to select the right vue file: -app.locals.development = app.get('env') === 'development'; +app.locals.development = (app.get('env') === 'development'); // view engine setup app.set('views', path.join(__dirname, 'views')); @@ -45,7 +44,35 @@ 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.userId = 0; //means "anonymous" + res.locals.user = { name: "" }; //"anonymous" + if (!req.cookies.token) + return next(); + UserModel.getOne("sessionToken", req.cookies.token, function(err, user) { + if (!!user) + { + req.userId = user.id; + res.locals.user = { + id: user.id, + name: user.name, + email: user.email, + notify: user.notify, + }; + } + else + { + // Token in cookies presumably wrong: erase it + res.clearCookie("token"); + } + 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) {