Files
standardnotes-server/packages/syncing-server/src/Infra/InversifyExpressUtils/Middleware/InversifyExpressAuthMiddleware.ts
Karol Sójko d13c975f94 chore: upgrade deps (#805)
* chore: upgrade semver

* chore: upgrade configure-aws-credentials@v2

* chore: upgrade prettier deps

* fix: linter issues
2023-09-01 16:14:51 +02:00

51 lines
1.6 KiB
TypeScript

import { NextFunction, Request, Response } from 'express'
import { BaseMiddleware } from 'inversify-express-utils'
import { verify } from 'jsonwebtoken'
import { CrossServiceTokenData } from '@standardnotes/security'
import * as winston from 'winston'
export class InversifyExpressAuthMiddleware extends BaseMiddleware {
constructor(
private authJWTSecret: string,
private logger: winston.Logger,
) {
super()
}
async handler(request: Request, response: Response, next: NextFunction): Promise<void> {
try {
if (!request.header('X-Auth-Token')) {
this.logger.debug('Missing X-Auth-Token header')
return this.sendInvalidAuthResponse(response)
}
const authToken = <string>request.header('X-Auth-Token')
const decodedToken = <CrossServiceTokenData>verify(authToken, this.authJWTSecret, { algorithms: ['HS256'] })
response.locals.user = decodedToken.user
response.locals.roles = decodedToken.roles
response.locals.session = decodedToken.session
response.locals.readOnlyAccess = decodedToken.session?.readonly_access ?? false
response.locals.sharedVaultOwnerContext = decodedToken.shared_vault_owner_context
response.locals.ongoingTransition = decodedToken.ongoing_transition
return next()
} catch (error) {
this.logger.error(`Could not verify JWT Auth Token ${(error as Error).message}`)
return this.sendInvalidAuthResponse(response)
}
}
private sendInvalidAuthResponse(response: Response) {
response.status(401).send({
error: {
tag: 'invalid-auth',
message: 'Invalid login credentials.',
},
})
}
}