access-token-parser.js 733 B

1234567891011121314151617181920212223242526272829
  1. const loggerFactory = require('@alias/logger');
  2. const logger = loggerFactory('growi:middleware:access-token-parser');
  3. module.exports = (crowi) => {
  4. return async(req, res, next) => {
  5. // TODO: comply HTTP header of RFC6750 / Authorization: Bearer
  6. const accessToken = req.query.access_token || req.body.access_token || null;
  7. if (!accessToken) {
  8. return next();
  9. }
  10. const User = crowi.model('User');
  11. logger.debug('accessToken is', accessToken);
  12. const user = await User.findUserByApiToken(accessToken);
  13. // transforming attributes
  14. // see User model
  15. req.user = user.toObject();
  16. req.skipCsrfVerify = true;
  17. logger.debug('Access token parsed: skipCsrfVerify');
  18. next();
  19. };
  20. };