access-token-parser.ts 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. import type { IUser, IUserHasId } from '@growi/core/dist/interfaces';
  2. import type { IUserSerializedSecurely } from '@growi/core/dist/models/serializers';
  3. import { serializeUserSecurely } from '@growi/core/dist/models/serializers';
  4. import type { NextFunction, Request, Response } from 'express';
  5. import type { HydratedDocument } from 'mongoose';
  6. import mongoose from 'mongoose';
  7. import loggerFactory from '~/utils/logger';
  8. const logger = loggerFactory('growi:middleware:access-token-parser');
  9. type ReqQuery = {
  10. access_token?: string,
  11. }
  12. type ReqBody = {
  13. access_token?: string,
  14. }
  15. interface Req extends Request<undefined, undefined, ReqBody, ReqQuery> {
  16. user: IUserSerializedSecurely<IUserHasId>,
  17. }
  18. const middlewareFactory = () => {
  19. return async(req: Req, res: Response, next: NextFunction): Promise<void> => {
  20. // TODO: comply HTTP header of RFC6750 / Authorization: Bearer
  21. const accessToken = req.query.access_token ?? req.body.access_token;
  22. if (accessToken == null || typeof accessToken !== 'string') {
  23. return next();
  24. }
  25. const User = mongoose.model<HydratedDocument<IUser>, { findUserByApiToken }>('User');
  26. logger.debug('accessToken is', accessToken);
  27. const user: IUserHasId = await User.findUserByApiToken(accessToken);
  28. if (user == null) {
  29. logger.debug('The access token is invalid');
  30. return next();
  31. }
  32. // transforming attributes
  33. req.user = serializeUserSecurely(user);
  34. logger.debug('Access token parsed.');
  35. return next();
  36. };
  37. };
  38. module.exports = middlewareFactory;
  39. // export default middlewareFactory;