2024-03-21 15:08:29 +01:00
|
|
|
import { CommandFactory } from 'nest-commander';
|
2024-06-06 12:56:57 +02:00
|
|
|
import { fork } from 'node:child_process';
|
2024-05-14 16:28:20 +02:00
|
|
|
import { Worker } from 'node:worker_threads';
|
2024-05-17 15:44:30 +02:00
|
|
|
import { ImmichAdminModule } from 'src/app.module';
|
2024-10-03 21:28:36 +02:00
|
|
|
import { ImmichWorker, LogLevel } from 'src/enum';
|
|
|
|
import { ConfigRepository } from 'src/repositories/config.repository';
|
2023-06-08 17:01:07 +02:00
|
|
|
|
2024-10-03 21:28:36 +02:00
|
|
|
const immichApp = process.argv[2];
|
|
|
|
if (immichApp) {
|
2023-06-08 17:01:07 +02:00
|
|
|
process.argv.splice(2, 1);
|
|
|
|
}
|
|
|
|
|
2024-10-03 21:28:36 +02:00
|
|
|
function bootstrapWorker(name: ImmichWorker) {
|
2024-05-17 15:44:30 +02:00
|
|
|
console.log(`Starting ${name} worker`);
|
2024-09-07 19:21:25 +02:00
|
|
|
|
2024-09-17 05:13:38 +02:00
|
|
|
const execArgv = process.execArgv.map((arg) => (arg.startsWith('--inspect') ? '--inspect=0.0.0.0:9231' : arg));
|
|
|
|
const worker =
|
|
|
|
name === 'api' ? fork(`./dist/workers/${name}.js`, [], { execArgv }) : new Worker(`./dist/workers/${name}.js`);
|
2024-09-07 19:21:25 +02:00
|
|
|
|
|
|
|
worker.on('error', (error) => {
|
|
|
|
console.error(`${name} worker error: ${error}`);
|
|
|
|
});
|
|
|
|
|
2024-05-14 16:28:20 +02:00
|
|
|
worker.on('exit', (exitCode) => {
|
|
|
|
if (exitCode !== 0) {
|
2024-05-17 15:44:30 +02:00
|
|
|
console.error(`${name} worker exited with code ${exitCode}`);
|
2024-05-14 16:28:20 +02:00
|
|
|
process.exit(exitCode);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2023-06-08 17:01:07 +02:00
|
|
|
function bootstrap() {
|
2024-10-03 21:28:36 +02:00
|
|
|
if (immichApp === 'immich-admin') {
|
|
|
|
process.title = 'immich_admin_cli';
|
|
|
|
process.env.IMMICH_LOG_LEVEL = LogLevel.WARN;
|
|
|
|
return CommandFactory.run(ImmichAdminModule);
|
2023-06-08 17:01:07 +02:00
|
|
|
}
|
2024-10-03 21:28:36 +02:00
|
|
|
|
|
|
|
if (immichApp === 'immich' || immichApp === 'microservices') {
|
|
|
|
console.error(
|
|
|
|
`Using "start.sh ${immichApp}" has been deprecated. See https://github.com/immich-app/immich/releases/tag/v1.118.0 for more information.`,
|
|
|
|
);
|
|
|
|
process.exit(1);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (immichApp) {
|
|
|
|
console.error(`Unknown command: "${immichApp}"`);
|
|
|
|
process.exit(1);
|
|
|
|
}
|
|
|
|
|
2024-05-17 16:10:57 +02:00
|
|
|
process.title = 'immich';
|
2024-10-03 21:28:36 +02:00
|
|
|
const { workers } = new ConfigRepository().getEnv();
|
|
|
|
for (const worker of workers) {
|
2024-05-17 16:10:57 +02:00
|
|
|
bootstrapWorker(worker);
|
|
|
|
}
|
2023-06-08 17:01:07 +02:00
|
|
|
}
|
2024-03-21 15:08:29 +01:00
|
|
|
|
2023-10-13 07:22:40 +02:00
|
|
|
void bootstrap();
|