main.ts 1.06 KB
Newer Older
1
import { ValidationPipe } from '@nestjs/common'
2
3
4
5
6
7
8
9
10
import { NestFactory } from '@nestjs/core'
import * as dotenv from 'dotenv'
import { WinstonModule } from 'nest-winston'
import * as winston from 'winston'
import { AppModule } from './app.module'
import { PaggesLogger } from './config/winston-logger/pagges-logger.utils'
import { winstonLoggerConfig } from './config/winston-logger/winston-config'

dotenv.config()
Guilherme Moraes's avatar
Guilherme Moraes committed
11
12

async function bootstrap() {
13
14
15
16
17
18
19
20
21
22
23
24
25
26
  if (!process.env.PORT) {
    throw new Error('PORT environment variable is required')
  }

  const rawWinstonLogger = winston.createLogger(winstonLoggerConfig)

  PaggesLogger.setLogger(rawWinstonLogger)

  const nestLogger = WinstonModule.createLogger(winstonLoggerConfig)

  const app = await NestFactory.create(AppModule, {
    logger: nestLogger,
  })

27
28
29
30
31
32
33
34
  app.useGlobalPipes(
    new ValidationPipe({
      whitelist: true,
      forbidNonWhitelisted: true,
      transform: true,
    }),
  )

35
36
  const { PORT } = process.env
  await app.listen(PORT)
Guilherme Moraes's avatar
Guilherme Moraes committed
37
}
38
39
40

// eslint-disable-next-line @typescript-eslint/no-floating-promises
bootstrap()