passport-refresh-token
v0.0.1
Published
Passport strategy to authenticate using a previously issued refresh token, and provide new access tokens for Oauth 2.0 flow.
Downloads
182
Maintainers
Readme
passport-refresh-token
Refresh token strategy for Passport.
This strategy is used to refresh the Oauth 2.0 access tokens issued by the server.
Install
$ npm install passport-refresh-token
Usage
Require Strategy
Require the passport-google-authcode
Strategy along with passport
var passport = require('passport');
var RefreshTokenStrategy = require('passport-refresh-token').Strategy;
Configure Strategy
The Refresh token strategy authenticates the request using the refresh token.
The strategy requires a verify
callback, which accepts that
credential and calls done
providing a user. Optional info
can be passed,
typically including associated scope, which will be set by Passport at
req.authInfo
to be used by later middleware for authorization and access
control.
passport.use(new RefreshTokenStrategy(
function(token, done) {
User.findOne({ token: token }, function (err, user) {
if (err) { return done(err); }
if (!user) { return done(null, false); }
return done(null, user, { scope: 'all' });
});
}
));
Authenticate Requests
Use passport.authenticate()
, specifying the 'refresh_token'
strategy, to
authenticate requests. Requests containing refresh tokens do not require session
support, so the session
option can be set to false
.
For example, as route middleware in an Express application:
app.get('/auth/token/refresh',
passport.authenticate('refresh_token', { session: false }),
function(req, res) {
// generate new tokens for req.user
res.json(tokens);
}
);
The post request to this route should include a JSON object with the key refresh_token
set to the refresh token issued earlier by the server.
Credits
License
Copyright (c) 2018 Shobhit Singhal