import { MiddlewareConsumer, Module, RequestMethod } from '@nestjs/common';
import { AppController } from './app.controller';
import { AppService } from './app.service';
import { ConfigModule, ConfigService } from '@nestjs/config';
import { TypeOrmModule } from '@nestjs/typeorm';
import { UserModule } from './user/user.module';
import { MultiFileUploadModule } from './multi-file-upload/multi-file-upload.module';
import { ApiLogInterceptor } from './api-logs/api-log.interceptor';
import { ApiLog } from './api-logs/entities/api-log.entity';
import { ApiLogsRepository } from './api-logs/api-log.repository';
import { CoursesModule } from './courses/courses.module';
import { CitiesModule } from './cities/cities.module';
import { JobModule } from './job/job.module';
import { PostsModule } from './posts/posts.module';
import { SponsorsModule } from './sponsors/sponsors.module';

@Module({
  imports: [
    ConfigModule.forRoot({
      isGlobal: true,
      envFilePath: '.env',
    }),
    TypeOrmModule.forRootAsync({
      useFactory: async (configService: ConfigService) => ({
        type: 'postgres',
        host: configService.get('DATABASE_HOST'),
        port: configService.get('DATABASE_PORT'),
        username: configService.get('DATABASE_USERNAME'),
        password: configService.get('DATABASE_PASSWORD'),
        database: configService.get('DATABASE_NAME'),
        synchronize: false,
        entities: [__dirname + '/**/*.entity{.ts,.js}'],
        logging: process.env.IS_LOGGING === 'true',
      }),
      inject: [ConfigService],
    }),
    TypeOrmModule.forFeature([ApiLog]),
    UserModule,
    MultiFileUploadModule,
    CoursesModule,
    CitiesModule,
    JobModule,
    PostsModule,
    SponsorsModule,
  ],
  controllers: [AppController],
  providers: [AppService, ApiLogsRepository],
})
export class AppModule {
  configure(consumer: MiddlewareConsumer) {
    consumer
      .apply(ApiLogInterceptor)
      .forRoutes({ path: '*', method: RequestMethod.ALL });
  }
}
