2020-04-05 16:58:33 +03:00
|
|
|
# Session From Token Middleware
|
|
|
|
|
|
|
|
Middleware to handle generating sessions from tokens, for example like with magic links, or SSO flows similar to SAML.
|
|
|
|
|
|
|
|
## Usage
|
|
|
|
|
|
|
|
```js
|
|
|
|
const sessionFromTokenMiddleware = require('@tryghost/mw-session-from-token')({
|
|
|
|
callNextWithError: true,
|
|
|
|
async createSession(req, res, user) {
|
|
|
|
req.session.user_id = user.id;
|
|
|
|
},
|
|
|
|
async getTokenFromRequest(res) {
|
|
|
|
return req.headers['some-cool-header'];
|
|
|
|
},
|
|
|
|
async getLookupFromToken(token) {
|
|
|
|
await someTokenService.validate(token);
|
|
|
|
const data = await someTokenService.getData(token);
|
|
|
|
return data.email;
|
|
|
|
},
|
|
|
|
async findUserByLookup(lookup) {
|
|
|
|
return await someUserModel.findOne({email: lookup});
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2024-05-06 18:26:14 +03:00
|
|
|
someExpressApp.get('/some/sso/url', someSessionMiddleware, sessionFromTokenMiddleware, function sessionFromTokenMiddleware(req, res, next) {
|
2020-04-05 16:58:33 +03:00
|
|
|
res.redirect('/loggedin');
|
2024-05-06 18:26:14 +03:00
|
|
|
}, function nextMw(err, res, res, next) => {
|
2020-04-05 16:58:33 +03:00
|
|
|
res.redirect('/error');
|
|
|
|
});
|
|
|
|
```
|