Skip to content

JSON Web Token middleware friendly with Express and Sails.js

License

Notifications You must be signed in to change notification settings

joshuamarquez/node-jwt-policy

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

39 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

jwt-policy

npm version

JSON Web Token middleware friendly with Express and Sails.js

Validates token from HTTP request header authorization and sets req.user, token is expected to be found at Authorization: Bearer <token>.

This module verifies tokens generated with node-jsonwebtoken

Install

$ npm install jwt-policy --save

Usage

jwtPolicy(options, [callback])

options :

  • secret : is a string containing the secret for decoding token.
  • extractToken : function to extract token instead of default (HTTP Authorization Header).
  • attachTo : allows the user to override the default path where the decoded token will be attached to, default is user.

Note: You can pass all available options for jwt.verify such as audience, issuer, etc.

Specify callback if you wish to do something with req.user or check for possible errors, if callback is not supplied then default behavior will take effect.

For default, jwt-policy extracts token using extractor-token (HTTP Authorization Header) but in case you are passing the token by any other method you can use extractToken option.

Usage in Sails.js

Default behavior

// Will return 401 HTTP status code if any errors occurred.
// policies/jwtAuth.js
module.exports = require('jwt-policy')({ secret: 'my_secret_key' });

Override default behavior

// policies/jwtAuth.js
module.exports = require('jwt-policy')({
  secret: 'my_secret_key'
}, function(err, req, res, next) {
  if (!err) {
    // user can be found at 'req.user'

    return next();
  }

  return res.status(401).json(err);
});

Override the way the token is extracted using extractToken option.

// policies/jwtAuth.js
module.exports = require('jwt-policy')({
  secret: 'my_secret_key',
  extractToken: function(req) {
    return req.param('token');
  }
});

Usage in Express

Default behavior

const jwtPolicy = require('jwt-policy');

app.get('/', jwtPolicy({ secret: 'my_secret_key' }), function(req, res) {
  res.send(req.user);
});

Override default behavior

const jwtPolicy = require('jwt-policy');

app.use(jwtPolicy({ secret: 'my_secret_key' }, function(err, req, res, next) {
  if (!err) {
    return res.next();
  }

  return res.status(401).json(err);
}));

app.get('/', function(req, res) {
  res.send(req.user);
});

Override the way the token is extracted using extractToken option.

app.use(jwtPolicy({
  secret: 'my_secret_key',
  extractToken: function(req) {
    return req.query.token;
  }
}));

Attach to

attachTo option usage example:

const jwtPolicy = require('jwt-policy');

app.use(jwtPolicy({
  secret: 'my_secret_key',
  attachTo: 'auth'
}));

app.get('/', function(req, res) {
  // decoded token can now 
  // be found at `req.auth`
  res.send(req.auth);
});

Error handling

Possible thrown errors

TokenExtractorError

message code
No Authorization header is present E_AUTHORIZATION_REQUIRED
Format is :: Authorization: Bearer E_AUTHORIZATION_INVALID_FORMAT
Authorization token was not found E_AUTHORIZATION_TOKEN_NOT_FOUND

JWTError

message code
JSON Web Token provided has expired E_TOKEN_EXPIRED
Invalid JSON Web Token provided E_TOKEN_INVALID

Suppose E_TOKEN_EXPIRED error was thrown

app.use(jwtPolicy({ secret: 'my_secret_key' }, function(err, req, res, next) {
  if (err) {
    console.log(err.toJSON());
    /*
      {
        status: 401,
        message: 'JSON Web Token provided has expired',
        code: 'E_TOKEN_EXPIRED'
      }
    */

    console.log(err.toString());
    /*
      [JWTError (E_TOKEN_EXPIRED) JSON Web Token provided has expired]
    */

    console.trace(err);
    /*
      prints Error Stack since err instanceof Error
    */
  }
}));

Test

$ npm test

About

JSON Web Token middleware friendly with Express and Sails.js

Resources

License

Stars

Watchers

Forks

Packages

No packages published