|
1 | | -import * as ChildProcess from 'node:child_process'; |
| 1 | +import { ChildProcess, fork } from 'node:child_process'; |
2 | 2 |
|
3 | 3 | import { config } from '../project-configs'; |
4 | 4 | import { validateTypeRecordStringUnknown } from '../utils/validator'; |
5 | 5 | import { PluginMessage } from './entities/message'; |
6 | | -import { Plugin } from './entities/plugin'; |
7 | 6 |
|
8 | 7 | export class PluginIpcBridge { |
9 | 8 |
|
10 | | - static async initializePlugin(directory: string, name: string): Promise<Plugin> { |
11 | | - const childProcess = ChildProcess.fork( |
| 9 | + async createProcess(directory: string, name: string): Promise<ChildProcess> { |
| 10 | + return fork( |
12 | 11 | directory + '/' + name + config.defaultPluginEntryPoint, |
13 | 12 | [], |
14 | 13 | { execArgv: ['-r', 'ts-node/register'], silent: true }, |
15 | 14 | ); |
16 | | - const plugin = new Plugin(directory, name, childProcess); |
17 | | - |
18 | | - childProcess.stdout!.on('data', (data) => { |
19 | | - console.log(data.toString()); |
20 | | - }); |
21 | | - |
22 | | - childProcess.stderr!.on('data', (data) => { |
23 | | - console.log(data.toString()); |
24 | | - }) |
25 | | - |
26 | | - await this.initializeResourceDefinitions(plugin); |
27 | | - |
28 | | - return plugin; |
29 | | - } |
30 | | - |
31 | | - static async initializeResourceDefinitions(plugin: Plugin): Promise<void> { |
32 | | - const resourceDefinitions = await this.sendMessageForResult(plugin, { cmd: 'getResourceDefinitions' }); |
33 | | - plugin.setResourceDefinitions(resourceDefinitions); |
34 | 15 | } |
35 | 16 |
|
36 | | - static killPlugin(plugin: Plugin): void { |
37 | | - plugin.process.kill(); |
| 17 | + killPlugin(process: ChildProcess): void { |
| 18 | + process.kill(); |
38 | 19 | } |
39 | 20 |
|
40 | | - private static async sendMessageForResult(plugin: Plugin, message: PluginMessage): Promise<unknown> { |
| 21 | + async sendMessageForResult(process: ChildProcess, message: PluginMessage): Promise<unknown> { |
41 | 22 | return new Promise((resolve, reject) => { |
42 | 23 | const timer = setTimeout(() => { |
43 | | - plugin.process.kill(); |
| 24 | + process.kill(); |
44 | 25 | reject(new Error(`Plugin did not respond in 10s to call: ${message.cmd}`)) |
45 | 26 | }, 10_000); |
46 | 27 |
|
47 | 28 | const errorListener = (error: Buffer) => { |
48 | | - plugin.process.kill(); |
| 29 | + process.kill(); |
49 | 30 | reject(error.toString()); |
50 | 31 | } |
51 | 32 |
|
52 | 33 | const messageListener = (incomingMessage: unknown) => { |
53 | 34 | console.log(incomingMessage); |
54 | 35 |
|
55 | 36 | if (!validateTypeRecordStringUnknown(incomingMessage)) { |
56 | | - return reject(new Error(`Bad message from plugin ${plugin.name}. ${JSON.stringify(incomingMessage, null, 2)}`)) |
| 37 | + return reject(new Error(`Bad message from plugin ${name}. ${JSON.stringify(incomingMessage, null, 2)}`)) |
57 | 38 | } |
58 | 39 |
|
59 | 40 | if (incomingMessage.cmd === this.getResultFunctionName(message.cmd)) { |
60 | 41 | clearTimeout(timer); |
61 | | - plugin.process.removeListener('message', messageListener); |
62 | | - plugin.process.removeListener('error', errorListener); |
| 42 | + process.removeListener('message', messageListener); |
| 43 | + process.removeListener('error', errorListener); |
63 | 44 | resolve(incomingMessage.data); |
64 | 45 | } |
65 | 46 | }; |
66 | 47 |
|
67 | | - plugin.process.on('message', messageListener); |
68 | | - plugin.process.stderr!.on('data', errorListener); |
69 | | - plugin.process.send(message); |
| 48 | + process.on('message', messageListener); |
| 49 | + process.stderr!.on('data', errorListener); |
| 50 | + process.send(message); |
70 | 51 | }); |
71 | 52 | } |
72 | 53 |
|
73 | | - private sendMessage(plugin: Plugin, message: PluginMessage): void { |
74 | | - plugin.process.send(message); |
| 54 | + sendMessage(process: ChildProcess, message: PluginMessage): void { |
| 55 | + process.send(message); |
75 | 56 | } |
76 | 57 |
|
77 | | - private static getResultFunctionName(rpcFunctionName: string): string { |
| 58 | + private getResultFunctionName(rpcFunctionName: string): string { |
78 | 59 | return rpcFunctionName + 'Result'; |
79 | 60 | } |
80 | 61 |
|
|
0 commit comments