InversifyExpressAuthMiddleware.ts 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  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(
  8. private authJWTSecret: string,
  9. private logger: winston.Logger,
  10. ) {
  11. super()
  12. }
  13. async handler(request: Request, response: Response, next: NextFunction): Promise<void> {
  14. try {
  15. if (!request.header('X-Auth-Token')) {
  16. this.logger.debug('Missing X-Auth-Token header')
  17. return this.sendInvalidAuthResponse(response)
  18. }
  19. const authToken = <string>request.header('X-Auth-Token')
  20. const decodedToken = <CrossServiceTokenData>verify(authToken, this.authJWTSecret, { algorithms: ['HS256'] })
  21. response.locals.user = decodedToken.user
  22. response.locals.roles = decodedToken.roles
  23. response.locals.session = decodedToken.session
  24. response.locals.readOnlyAccess = decodedToken.session?.readonly_access ?? false
  25. response.locals.sharedVaultOwnerContext = decodedToken.shared_vault_owner_context
  26. response.locals.ongoingTransition = decodedToken.ongoing_transition
  27. return next()
  28. } catch (error) {
  29. this.logger.error(`Could not verify JWT Auth Token ${(error as Error).message}`)
  30. return this.sendInvalidAuthResponse(response)
  31. }
  32. }
  33. private sendInvalidAuthResponse(response: Response) {
  34. response.status(401).send({
  35. error: {
  36. tag: 'invalid-auth',
  37. message: 'Invalid login credentials.',
  38. },
  39. })
  40. }
  41. }