X-Git-Url: https://git.auder.net/?a=blobdiff_plain;f=app.js;h=e63aca44b7ec0f35954d6e4106d25a300733e537;hb=26b8e4f7c71030d49e44fe1d89632ef91b886d67;hp=e32ef39e7d88653bb2b6d55f60e1a2f2f4f13411;hpb=9234226104764b91df9d677fb360ad538b98510c;p=vchess.git diff --git a/app.js b/app.js index e32ef39e..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(); @@ -27,6 +26,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 +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) {