|
1 | | -import { execa } from 'execa'; |
2 | 1 | import { Command, CommandRunner, Option } from 'nest-commander'; |
3 | 2 |
|
4 | 3 | import type { LogLevel } from '@app/core/log'; |
5 | | -import { ECOSYSTEM_PATH, PM2_PATH } from '@app/consts'; |
| 4 | +import { ECOSYSTEM_PATH } from '@app/consts'; |
6 | 5 | import { levels } from '@app/core/log'; |
7 | 6 | import { LogService } from '@app/unraid-api/cli/log.service'; |
| 7 | +import { PM2Service } from '@app/unraid-api/cli/pm2.service'; |
8 | 8 |
|
9 | 9 | interface StartCommandOptions { |
10 | 10 | 'log-level'?: string; |
11 | 11 | } |
12 | 12 |
|
13 | 13 | @Command({ name: 'start' }) |
14 | 14 | export class StartCommand extends CommandRunner { |
15 | | - constructor(private readonly logger: LogService) { |
| 15 | + constructor( |
| 16 | + private readonly logger: LogService, |
| 17 | + private readonly pm2: PM2Service |
| 18 | + ) { |
16 | 19 | super(); |
17 | 20 | } |
18 | 21 |
|
19 | 22 | async cleanupPM2State() { |
20 | | - await execa(PM2_PATH, ['stop', ECOSYSTEM_PATH]) |
21 | | - .then(({ stdout }) => this.logger.debug(stdout)) |
22 | | - .catch(({ stderr }) => this.logger.error('PM2 Stop Error: ' + stderr)); |
23 | | - await execa(PM2_PATH, ['delete', ECOSYSTEM_PATH]) |
24 | | - .then(({ stdout }) => this.logger.debug(stdout)) |
25 | | - .catch(({ stderr }) => this.logger.error('PM2 Delete API Error: ' + stderr)); |
26 | | - |
27 | | - // Update PM2 |
28 | | - await execa(PM2_PATH, ['update']) |
29 | | - .then(({ stdout }) => this.logger.debug(stdout)) |
30 | | - .catch(({ stderr }) => this.logger.error('PM2 Update Error: ' + stderr)); |
| 23 | + await this.pm2.run({ tag: 'PM2 Stop' }, 'stop', ECOSYSTEM_PATH); |
| 24 | + await this.pm2.run({ tag: 'PM2 Update' }, 'update'); |
| 25 | + await this.pm2.deleteDump(); |
| 26 | + await this.pm2.run({ tag: 'PM2 Delete' }, 'delete', ECOSYSTEM_PATH); |
31 | 27 | } |
32 | 28 |
|
33 | 29 | async run(_: string[], options: StartCommandOptions): Promise<void> { |
34 | 30 | this.logger.info('Starting the Unraid API'); |
35 | 31 | await this.cleanupPM2State(); |
36 | | - const envLog = options['log-level'] ? `LOG_LEVEL=${options['log-level']}` : ''; |
37 | | - const { stderr, stdout } = await execa(`${envLog} ${PM2_PATH}`.trim(), [ |
| 32 | + |
| 33 | + const env: Record<string, string> = {}; |
| 34 | + if (options['log-level']) { |
| 35 | + env.LOG_LEVEL = options['log-level']; |
| 36 | + } |
| 37 | + |
| 38 | + const { stderr, stdout } = await this.pm2.run( |
| 39 | + { tag: 'PM2 Start', env, raw: true }, |
38 | 40 | 'start', |
39 | 41 | ECOSYSTEM_PATH, |
40 | | - '--update-env', |
41 | | - ]); |
| 42 | + '--update-env' |
| 43 | + ); |
42 | 44 | if (stdout) { |
43 | | - this.logger.log(stdout); |
| 45 | + this.logger.log(stdout.toString()); |
44 | 46 | } |
45 | 47 | if (stderr) { |
46 | | - this.logger.error(stderr); |
| 48 | + this.logger.error(stderr.toString()); |
47 | 49 | process.exit(1); |
48 | 50 | } |
49 | | - process.exit(0); |
50 | 51 | } |
51 | 52 |
|
52 | 53 | @Option({ |
|
0 commit comments