Using a combination of Express-session, Connect-mongo and PassportJS on a Node server I have the following validation function:
expressApp.post('/login', function(req, res, next) {
passport.authenticate('login', function(err, user, info) {
if(err) {
return console.log(err);
}
if(!user){
res.set('WWW-Authenticate', 'x' + info);
return res.send(401);
}
req.login(user, function(err){
if(err) {
return console.log(err);
}
//I WANT TO ACCESS OUTGOING COOKIE HERE
//var cookie = res.get('SET-COOKIE');
res.redirect('/homepage');
});
}
)(req, res, next)
}
);
As you can see in the commented part, I want to access the cookie information before response is sent to the client. I haven't been able to find any such data within the 'res' and 'user' object.
Specifically I'm looking for the same string you can locate within the 'SET-COOKIE' header in a HTTP response.
The SET-COOKIE header string is created within Express-session\index.js after calling i.e res.redirect(..) from your personal code.
Find the function 'setcookie' and you will be able to access the raw string (and tamper with its creation if you so wish). Currently this means customizing the internal express-session code which is not ideal.
EDIT: I have received a secondary suggestion from Douglas Wilson, contributor/developer for Express-session:
The express-session module does not provide any real interface to examine it before it sets it on the Node.js HTTP response object, but you can get to it before the response is sent, which may or may not work depending on your use-case, using the on-headers module to see headers getting sent to the client: