A refresh token authentication strategy for Passport
You can install this package using yarn
or npm
.
#yarn
yarn add @meanie/passport-refresh-strategy
#npm
npm install @meanie/passport-refresh-strategy --save
//Dependencies
const passport = require('passport');
const jwt = require('@meanie/express-jsonwebtoken');
const RefreshStrategy = require('@meanie/passport-refresh-strategy');
const {InvalidTokenError} = jwt;
//Your custom user service
const User = require('./user.service');
//Setup strategy
passport.use(new RefreshStrategy((refreshToken, cb) => {
//No refresh token?
if (!refreshToken) {
return cb(null, false);
}
//Validate token
jwt
.validate(refreshToken)
.then(User.findByTokenPayload)
.then(user => {
if (!user) {
throw new InvalidTokenError('No matching user found');
}
return cb(null, user);
})
.catch(cb);
}));
Please report any bugs, issues, suggestions and feature requests in the @meanie/passport-refresh-strategy issue tracker.
Pull requests are welcome! If you would like to contribute to Meanie, please check out the Meanie contributing guidelines.
This package has been kindly sponsored by Hello Club, an all in one club and membership management solution complete with booking system, automated membership renewals, online payments and integrated access and light control. Check us out if you happen to belong to any kind of club or if you know someone who helps run a club!
(MIT License)
Copyright 2016-2020, Adam Reis