2024-05-14 15:28:20 +01:00
|
|
|
import { NestFactory } from '@nestjs/core';
|
|
|
|
import { isMainThread } from 'node:worker_threads';
|
|
|
|
import { MicroservicesModule } from 'src/app.module';
|
2024-10-03 17:49:03 -04:00
|
|
|
import { serverVersion } from 'src/constants';
|
2024-05-14 15:28:20 +01:00
|
|
|
import { ILoggerRepository } from 'src/interfaces/logger.interface';
|
|
|
|
import { WebSocketAdapter } from 'src/middleware/websocket.adapter';
|
2024-10-17 17:00:22 -04:00
|
|
|
import { ConfigRepository } from 'src/repositories/config.repository';
|
2024-10-21 19:52:30 -04:00
|
|
|
import { bootstrapTelemetry } from 'src/repositories/telemetry.repository';
|
2024-10-31 13:42:58 -04:00
|
|
|
import { isStartUpError } from 'src/utils/misc';
|
2024-05-14 15:28:20 +01:00
|
|
|
|
2024-05-17 14:44:30 +01:00
|
|
|
export async function bootstrap() {
|
2024-10-17 17:00:22 -04:00
|
|
|
const { telemetry } = new ConfigRepository().getEnv();
|
2024-10-24 23:07:32 +02:00
|
|
|
if (telemetry.metrics.size > 0) {
|
2024-10-21 19:52:30 -04:00
|
|
|
bootstrapTelemetry(telemetry.microservicesPort);
|
|
|
|
}
|
2024-05-14 15:28:20 +01:00
|
|
|
|
|
|
|
const app = await NestFactory.create(MicroservicesModule, { bufferLogs: true });
|
|
|
|
const logger = await app.resolve(ILoggerRepository);
|
2024-06-05 17:07:47 -04:00
|
|
|
logger.setContext('Bootstrap');
|
2024-05-14 15:28:20 +01:00
|
|
|
app.useLogger(logger);
|
|
|
|
app.useWebSocketAdapter(new WebSocketAdapter(app));
|
|
|
|
|
2024-05-17 12:59:05 -04:00
|
|
|
await app.listen(0);
|
2024-05-14 15:28:20 +01:00
|
|
|
|
2025-01-21 13:13:09 -05:00
|
|
|
const configRepository = app.get(ConfigRepository);
|
2024-10-03 17:49:03 -04:00
|
|
|
const { environment } = configRepository.getEnv();
|
|
|
|
logger.log(`Immich Microservices is running [v${serverVersion}] [${environment}] `);
|
2024-05-14 15:28:20 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (!isMainThread) {
|
2024-05-17 14:44:30 +01:00
|
|
|
bootstrap().catch((error) => {
|
2024-09-07 13:21:25 -04:00
|
|
|
if (!isStartUpError(error)) {
|
|
|
|
console.error(error);
|
|
|
|
}
|
|
|
|
throw error;
|
2024-05-14 15:28:20 +01:00
|
|
|
});
|
|
|
|
}
|