1
0
mirror of https://github.com/immich-app/immich.git synced 2025-07-07 06:16:05 +02:00
Files
immich/server/src/app.module.ts

120 lines
4.2 KiB
TypeScript
Raw Normal View History

import { BullModule } from '@nestjs/bullmq';
import { Inject, Module, OnModuleDestroy, OnModuleInit, ValidationPipe } from '@nestjs/common';
import { ConfigModule } from '@nestjs/config';
import { APP_FILTER, APP_GUARD, APP_INTERCEPTOR, APP_PIPE, ModuleRef } from '@nestjs/core';
import { ScheduleModule, SchedulerRegistry } from '@nestjs/schedule';
import { TypeOrmModule } from '@nestjs/typeorm';
2024-08-15 16:12:41 -04:00
import _ from 'lodash';
import { ClsModule } from 'nestjs-cls';
import { OpenTelemetryModule } from 'nestjs-otel';
import { commands } from 'src/commands';
import { bullConfig, bullQueues, clsConfig, immichAppConfig } from 'src/config';
import { controllers } from 'src/controllers';
2024-03-20 22:15:09 -05:00
import { databaseConfig } from 'src/database.config';
import { entities } from 'src/entities';
import { IEventRepository } from 'src/interfaces/event.interface';
2024-08-15 16:12:41 -04:00
import { ILoggerRepository } from 'src/interfaces/logger.interface';
2024-03-21 09:08:29 -05:00
import { AuthGuard } from 'src/middleware/auth.guard';
import { ErrorInterceptor } from 'src/middleware/error.interceptor';
import { FileUploadInterceptor } from 'src/middleware/file-upload.interceptor';
import { GlobalExceptionFilter } from 'src/middleware/global-exception.filter';
import { LoggingInterceptor } from 'src/middleware/logging.interceptor';
import { repositories } from 'src/repositories';
import { services } from 'src/services';
import { DatabaseService } from 'src/services/database.service';
import { setupEventHandlers } from 'src/utils/events';
2024-03-20 22:15:09 -05:00
import { otelConfig } from 'src/utils/instrumentation';
const common = [...services, ...repositories];
2024-03-21 09:08:29 -05:00
const middleware = [
FileUploadInterceptor,
{ provide: APP_FILTER, useClass: GlobalExceptionFilter },
2024-03-21 09:08:29 -05:00
{ provide: APP_PIPE, useValue: new ValidationPipe({ transform: true, whitelist: true }) },
{ provide: APP_INTERCEPTOR, useClass: LoggingInterceptor },
2024-03-21 09:08:29 -05:00
{ provide: APP_INTERCEPTOR, useClass: ErrorInterceptor },
{ provide: APP_GUARD, useClass: AuthGuard },
];
const imports = [
BullModule.forRoot(bullConfig),
BullModule.registerQueue(...bullQueues),
ClsModule.forRoot(clsConfig),
2024-03-21 09:08:29 -05:00
ConfigModule.forRoot(immichAppConfig),
OpenTelemetryModule.forRoot(otelConfig),
TypeOrmModule.forRootAsync({
inject: [ModuleRef],
useFactory: (moduleRef: ModuleRef) => {
return {
...databaseConfig,
poolErrorHandler: (error) => {
moduleRef.get(DatabaseService, { strict: false }).handleConnectionError(error);
},
};
},
}),
TypeOrmModule.forFeature(entities),
2024-03-21 09:08:29 -05:00
];
@Module({
2024-03-21 09:08:29 -05:00
imports: [...imports, ScheduleModule.forRoot()],
controllers: [...controllers],
providers: [...common, ...middleware],
2024-03-21 09:08:29 -05:00
})
export class ApiModule implements OnModuleInit, OnModuleDestroy {
constructor(
private moduleRef: ModuleRef,
@Inject(IEventRepository) private eventRepository: IEventRepository,
2024-08-15 16:12:41 -04:00
@Inject(ILoggerRepository) private logger: ILoggerRepository,
) {
logger.setAppName('Api');
}
2024-03-21 09:08:29 -05:00
async onModuleInit() {
2024-08-15 16:12:41 -04:00
const items = setupEventHandlers(this.moduleRef);
2024-08-27 18:06:50 -04:00
await this.eventRepository.emit('app.bootstrap', 'api');
2024-08-15 16:12:41 -04:00
this.logger.setContext('EventLoader');
const eventMap = _.groupBy(items, 'event');
for (const [event, handlers] of Object.entries(eventMap)) {
for (const { priority, label } of handlers) {
this.logger.verbose(`Added ${event} {${label}${priority ? '' : ', ' + priority}} event`);
}
}
}
async onModuleDestroy() {
2024-08-27 18:06:50 -04:00
await this.eventRepository.emit('app.shutdown');
2024-03-21 09:08:29 -05:00
}
}
@Module({
imports: [...imports],
providers: [...common, SchedulerRegistry],
})
export class MicroservicesModule implements OnModuleInit, OnModuleDestroy {
constructor(
private moduleRef: ModuleRef,
@Inject(IEventRepository) private eventRepository: IEventRepository,
@Inject(ILoggerRepository) logger: ILoggerRepository,
) {
logger.setAppName('Microservices');
}
2024-03-21 09:08:29 -05:00
async onModuleInit() {
setupEventHandlers(this.moduleRef);
2024-08-27 18:06:50 -04:00
await this.eventRepository.emit('app.bootstrap', 'microservices');
}
async onModuleDestroy() {
2024-08-27 18:06:50 -04:00
await this.eventRepository.emit('app.shutdown');
2024-03-21 09:08:29 -05:00
}
}
@Module({
imports: [...imports],
providers: [...common, ...commands, SchedulerRegistry],
2024-03-21 09:08:29 -05:00
})
export class ImmichAdminModule {}