From 543c211972781fe16625016c3d1f329663f0c6d3 Mon Sep 17 00:00:00 2001 From: Sam Pinkus Date: Fri, 29 Jul 2022 15:24:26 +1000 Subject: [PATCH] Pass new session as extra param to Session reload and regenerate callback. --- README.md | 4 ++-- session/session.js | 13 +++++++------ session/store.js | 2 +- 3 files changed, 10 insertions(+), 9 deletions(-) diff --git a/README.md b/README.md index 45e68a98..8d442ac1 100644 --- a/README.md +++ b/README.md @@ -341,7 +341,7 @@ a new SID and `Session` instance will be initialized at `req.session` and the `callback` will be invoked. ```js -req.session.regenerate(function(err) { +req.session.regenerate(function(err, session) { // will have a new session here }) ``` @@ -363,7 +363,7 @@ Reloads the session data from the store and re-populates the `req.session` object. Once complete, the `callback` will be invoked. ```js -req.session.reload(function(err) { +req.session.reload(function(err, session) { // session updated }) ``` diff --git a/session/session.js b/session/session.js index fee7608c..a0662ea7 100644 --- a/session/session.js +++ b/session/session.js @@ -75,10 +75,10 @@ defineMethod(Session.prototype, 'save', function save(fn) { /** * Re-loads the session data _without_ altering - * the maxAge properties. Invokes the callback `fn(err)`, + * the maxAge properties. Invokes the callback `fn(err, session)`, * after which time if no exception has occurred the - * `req.session` property will be a new `Session` object, - * although representing the same session. + * `req.session` property and `session` callback param will be + * the new `Session` object, although representing the same session. * * @param {Function} fn * @return {Session} for chaining @@ -93,7 +93,7 @@ defineMethod(Session.prototype, 'reload', function reload(fn) { if (err) return fn(err); if (!sess) return fn(new Error('failed to load session')); store.createSession(req, sess); - fn(); + fn(null, req.session); }); return this; }); @@ -113,7 +113,8 @@ defineMethod(Session.prototype, 'destroy', function destroy(fn) { }); /** - * Regenerate this request's session. + * Regenerate this request's session. Invokes the callback `fn(err, session)` + * with the new session object or an error if one occurred. * * @param {Function} fn * @return {Session} for chaining @@ -140,4 +141,4 @@ function defineMethod(obj, name, fn) { value: fn, writable: true }); -}; +} diff --git a/session/store.js b/session/store.js index 3793877e..68428322 100644 --- a/session/store.js +++ b/session/store.js @@ -51,7 +51,7 @@ Store.prototype.regenerate = function(req, fn){ var self = this; this.destroy(req.sessionID, function(err){ self.generate(req); - fn(err); + fn(err, req.session); }); };