mirror of
https://github.com/TryGhost/Ghost.git
synced 2024-11-23 22:11:09 +03:00
e5d097fbae
- @tryghost/adapter-manager@0.2.30 - @tryghost/api-version-compatibility-service@0.1.2 - @tryghost/bootstrap-socket@0.2.19 - @tryghost/config-url-helpers@0.1.7 - @tryghost/constants@1.0.4 - @tryghost/database-info@0.3.4 - @tryghost/email-content-generator@0.1.0 - @tryghost/image-transform@1.0.31 - @tryghost/job-manager@0.8.23 - @tryghost/limit-service@1.1.1 - @tryghost/minifier@0.1.14 - @tryghost/moleculer-service-from-class@0.2.25 - @tryghost/mw-api-version-mismatch@0.1.2 - @tryghost/mw-error-handler@0.2.3 - @tryghost/mw-session-from-token@0.1.31 - @tryghost/mw-update-user-last-seen@0.1.5 - @tryghost/package-json@1.0.20 - @tryghost/pretty-cli@1.2.26 - @tryghost/promise@0.1.17 - @tryghost/release-utils@0.7.14 - @tryghost/security@0.2.17 - @tryghost/session-service@0.1.41 - @tryghost/settings-path-manager@0.1.6 - @tryghost/update-check-service@0.3.3 - @tryghost/version-notifications-data-service@0.1.1 - @tryghost/vhost-middleware@1.0.25 - @tryghost/zip@1.1.24 |
||
---|---|---|
.. | ||
lib | ||
test | ||
types | ||
.eslintignore | ||
.eslintrc.js | ||
index.js | ||
LICENSE | ||
package.json | ||
README.md | ||
tsconfig.json |
Session From Token Middleware
Middleware to handle generating sessions from tokens, for example like with magic links, or SSO flows similar to SAML.
Install
npm install @tryghost/mw-session-from-token --save
or
yarn add @tryghost/mw-session-from-token
Usage
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});
}
});
someExpressApp.get('/some/sso/url', someSessionMiddleware, sessionFromTokenMiddleware, (req, res, next) => {
res.redirect('/loggedin');
}, (err, res, res, next) => {
res.redirect('/error');
});
Develop
This is a mono repository, managed with lerna.
Follow the instructions for the top-level repo.
git clone
this repo &cd
into it as usual- Run
yarn
to install top-level dependencies.
Run
yarn dev
Test
yarn lint
run just eslintyarn test
run lint and tests
Copyright & License
Copyright (c) 2013-2022 Ghost Foundation - Released under the MIT license.