Search code examples
javascriptnode.jsexpresscouchdbmiddleware

call middleware function in router


I'm implementing sessions on my express.js app with Mozilla’s client-sessions and I need some help. I have my post and gest request in my router.js and the middleware in app.js, I get this error when I run it :

ReferenceError: requireLogin is not defined

//index.js (router)

var express = require('express')
  , router = express.Router()
  , user = require('../public/js/models/test.js');



router.get('/profile-header', requireLogin, function (req, res, html) {
  console.log(req.session);
  res.render('templates/profile-header.jade', { title: 'Default' })
});


router.get('/sign-in', function (req, res, html) {
  res.render('templates/sign-in.jade', { title: 'Sign In' })
});


router.get('/blog-home', requireLogin, function (req, res, html) {
  res.render('templates/blog-home.jade', { title: 'Blog' })
});


router.get('/logout', function(req, res) {
  req.session.reset();
  res.redirect('/');
});


router.post('/profile-header', function (req, res, html) {
  user.login(req.body,  function (e, o) {
    if (o) {
      //add session
      req.session.user = o;
      res.redirect('/profile-header');
    } else {
      res.render('templates/sign-in.jade', { error: 'Invalid email or password.' });
    }
  });
});

module.exports = router;

//app.js

var express = require('express');
var path = require('path');
var favicon = require('serve-favicon');
var logger = require('morgan');
var cookieParser = require('cookie-parser');
var bodyParser = require('body-parser');
var stylus = require('stylus');
var bcrypt = require('bcrypt');
var should = require('should');
var session = require('client-sessions');

var index = require('./routes/index');
var users = require('./routes/users');
var app = express();

// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'jade');
// uncomment after placing your favicon in /public
//app.use(favicon(path.join(__dirname, 'public', 'favicon.ico')));
function requireLogin (req, res, next) {
  if (!req.user) {
    console.log("pd");
    res.redirect('/sign-in');
  } else {
    next();
  }
};


app.use(session({
  cookieName: 'session',
  secret: 'random_string_goes_here',
  duration: 30 * 60 * 1000,
  activeDuration: 5 * 60 * 1000,
}));

app.use(logger('dev'));
app.use(bodyParser.urlencoded({ extended: true }));
app.use(bodyParser.json());
app.use(cookieParser());
app.use(stylus.middleware(path.join(__dirname, 'public')));
app.use(express.static(path.join(__dirname, 'public')));
app.use(function(req, res, next) {
  res.header("Access-Control-Allow-Origin", "*");
  res.header("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept");
  next();
});

app.use('/', index);
app.use('/users', users);


app.use(function(req, res, next) {
  if (req.session && req.session.user) {
     user.exist(req.session.username, function  (e, o) {
      if (user) {
        req.user = user;
        delete req.user.user_password; // delete the password from the session
        req.session.user = user;  //refresh the session value
        console.log(req.session);
        res.locals.user = user;
      }
      // finishing processing the middleware and run the route
      next();
    });
  } else {
    next();
  }
});
// listener
app.listen(process.env.PORT || 3000, function () {
	console.log('Listening on http://localhost:' + (process.env.PORT || 3000))
})

module.exports = app;

Thx for your help !


Solution

  • The problem is that requireLogin is defined in app.js, but in index.js it's not defined. I'd suggest to move requireLogin in an external service and import/require it when needed:

    // auth.service.js
    exports.requireLogin = function (req, res, next) { ... };
    

    Then in index.js add this:

    var Auth = require('./auth.service');
    
    ....
    
    router.get('/profile-header', Auth.requireLogin, function (req, res, html) {
      console.log(req.session);
      res.render('templates/profile-header.jade', { title: 'Default' })
    });