61 lines
1.9 KiB
TypeScript
61 lines
1.9 KiB
TypeScript
|
import 'reflect-metadata'
|
||
|
|
||
|
import * as cors from 'cors'
|
||
|
import { urlencoded, json, Request, Response, NextFunction } from 'express'
|
||
|
import * as winston from 'winston'
|
||
|
|
||
|
import { InversifyExpressServer } from 'inversify-express-utils'
|
||
|
import TYPES from '../src/Bootstrap/Types'
|
||
|
import { Env } from '../src/Bootstrap/Env'
|
||
|
import { ContainerConfigLoader } from '../src/Bootstrap/Container'
|
||
|
|
||
|
import '../src/Infra/InversifyExpress/AnnotatedRevisionsController'
|
||
|
import '../src/Infra/InversifyExpress/AnnotatedHealthCheckController'
|
||
|
|
||
|
const container = new ContainerConfigLoader()
|
||
|
void container.load().then((container) => {
|
||
|
const env: Env = container.get(TYPES.Revisions_Env)
|
||
|
|
||
|
const server = new InversifyExpressServer(container)
|
||
|
|
||
|
server.setConfig((app) => {
|
||
|
app.use((_request: Request, response: Response, next: NextFunction) => {
|
||
|
response.setHeader('X-Revisions-Version', container.get(TYPES.Revisions_VERSION))
|
||
|
next()
|
||
|
})
|
||
|
app.use(json())
|
||
|
app.use(urlencoded({ extended: true }))
|
||
|
app.use(cors())
|
||
|
})
|
||
|
|
||
|
const logger: winston.Logger = container.get(TYPES.Revisions_Logger)
|
||
|
|
||
|
server.setErrorConfig((app) => {
|
||
|
app.use((error: Record<string, unknown>, _request: Request, response: Response, _next: NextFunction) => {
|
||
|
logger.error(error.stack)
|
||
|
|
||
|
response.status(500).send({
|
||
|
error: {
|
||
|
message:
|
||
|
"Unfortunately, we couldn't handle your request. Please try again or contact our support if the error persists.",
|
||
|
},
|
||
|
})
|
||
|
})
|
||
|
})
|
||
|
|
||
|
const serverInstance = server.build().listen(env.get('PORT'))
|
||
|
|
||
|
const keepAliveTimeout = env.get('HTTP_KEEP_ALIVE_TIMEOUT', true) ? +env.get('HTTP_KEEP_ALIVE_TIMEOUT', true) : 5000
|
||
|
|
||
|
serverInstance.keepAliveTimeout = keepAliveTimeout
|
||
|
|
||
|
process.on('SIGTERM', () => {
|
||
|
logger.info('SIGTERM signal received: closing HTTP server')
|
||
|
serverInstance.close(() => {
|
||
|
logger.info('HTTP server closed')
|
||
|
})
|
||
|
})
|
||
|
|
||
|
logger.info(`Server started on port ${process.env.PORT}`)
|
||
|
})
|