access-token-parser.ts 948 B

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