access-token-parser.js 905 B

123456789101112131415161718192021222324252627282930313233343536
  1. import { serializeUserSecurely } from '@growi/core/dist/models/serializers';
  2. import loggerFactory from '~/utils/logger';
  3. const logger = loggerFactory('growi:middleware:access-token-parser');
  4. module.exports = (crowi) => {
  5. return async(req, res, next) => {
  6. // TODO: comply HTTP header of RFC6750 / Authorization: Bearer
  7. const accessToken = req.query.access_token || req.body.access_token || null;
  8. if (accessToken == null || typeof accessToken !== 'string') {
  9. return next();
  10. }
  11. const User = crowi.model('User');
  12. logger.debug('accessToken is', accessToken);
  13. const user = await User.findUserByApiToken(accessToken);
  14. if (user == null) {
  15. logger.debug('The access token is invalid');
  16. return next();
  17. }
  18. // transforming attributes
  19. req.user = serializeUserSecurely(user);
  20. logger.debug('Access token parsed.');
  21. return next();
  22. };
  23. };