InversifyExpressAuthMiddleware.ts 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. import { NextFunction, Request, Response } from 'express'
  2. import { BaseMiddleware } from 'inversify-express-utils'
  3. import { verify } from 'jsonwebtoken'
  4. import { CrossServiceTokenData } from '@standardnotes/security'
  5. import * as winston from 'winston'
  6. export class InversifyExpressAuthMiddleware extends BaseMiddleware {
  7. constructor(private authJWTSecret: string, private logger: winston.Logger) {
  8. super()
  9. }
  10. async handler(request: Request, response: Response, next: NextFunction): Promise<void> {
  11. try {
  12. if (!request.header('X-Auth-Token')) {
  13. this.logger.debug('Missing X-Auth-Token header')
  14. return this.sendInvalidAuthResponse(response)
  15. }
  16. const authToken = <string>request.header('X-Auth-Token')
  17. const decodedToken = <CrossServiceTokenData>verify(authToken, this.authJWTSecret, { algorithms: ['HS256'] })
  18. response.locals.user = decodedToken.user
  19. response.locals.roles = decodedToken.roles
  20. response.locals.session = decodedToken.session
  21. response.locals.readOnlyAccess = decodedToken.session?.readonly_access ?? false
  22. return next()
  23. } catch (error) {
  24. this.logger.error(`Could not verify JWT Auth Token ${(error as Error).message}`)
  25. return this.sendInvalidAuthResponse(response)
  26. }
  27. }
  28. private sendInvalidAuthResponse(response: Response) {
  29. response.status(401).send({
  30. error: {
  31. tag: 'invalid-auth',
  32. message: 'Invalid login credentials.',
  33. },
  34. })
  35. }
  36. }