access-token.ts 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. import type { IUserHasId } from '@growi/core/dist/interfaces';
  2. import { serializeUserSecurely } from '@growi/core/dist/models/serializers';
  3. import type { NextFunction, Response } from 'express';
  4. import type { Scope } from '~/interfaces/scope';
  5. import { AccessToken } from '~/server/models/access-token';
  6. import loggerFactory from '~/utils/logger';
  7. import type { AccessTokenParserReq } from './interfaces';
  8. const logger = loggerFactory('growi:middleware:access-token-parser:access-token');
  9. export const parserForAccessToken = (scopes: Scope[]) => {
  10. return async(req: AccessTokenParserReq, res: Response, next: NextFunction): Promise<void> => {
  11. const accessToken = req.query.access_token ?? req.body.access_token;
  12. if (accessToken == null || typeof accessToken !== 'string') {
  13. return;
  14. }
  15. if (scopes == null || scopes.length === 0) {
  16. logger.debug('scopes is empty');
  17. return;
  18. }
  19. // check the access token is valid
  20. const userId = await AccessToken.findUserIdByToken(accessToken, scopes);
  21. if (userId == null) {
  22. logger.debug('The access token is invalid');
  23. return;
  24. }
  25. // check the user is valid
  26. const { user: userByAccessToken }: {user: IUserHasId} = await userId.populate('user');
  27. if (userByAccessToken == null) {
  28. logger.debug('The access token\'s associated user is invalid');
  29. return;
  30. }
  31. // transforming attributes
  32. req.user = serializeUserSecurely(userByAccessToken);
  33. if (req.user == null) {
  34. return;
  35. }
  36. logger.debug('Access token parsed.');
  37. return;
  38. };
  39. };