2019-08-22 12:49:29 +02:00
|
|
|
import { expose } from '@pushrocks/smartspawn';
|
2019-08-22 13:20:41 +02:00
|
|
|
import * as plugins from './smartproxy.plugins';
|
|
|
|
import * as cluster from 'cluster';
|
2019-08-22 12:49:29 +02:00
|
|
|
|
|
|
|
class ProxyMaster {
|
2019-08-22 13:20:41 +02:00
|
|
|
public hostCandidates: plugins.tsclass.network.IReverseProxyConfig[] = [];
|
2019-08-22 12:49:29 +02:00
|
|
|
public clusterChilds: any[] = [];
|
2019-08-22 13:20:41 +02:00
|
|
|
public smartsystem = new plugins.smartsystem.Smartsystem();
|
2019-08-22 12:49:29 +02:00
|
|
|
|
2019-08-22 13:20:41 +02:00
|
|
|
public async start() {
|
|
|
|
if (cluster.isMaster) {
|
|
|
|
console.log('ProxyMaster registered as cluster master');
|
|
|
|
console.log(`should spawn ${this.smartsystem.cpus.length} workers`);
|
|
|
|
for (const cpu of this.smartsystem.cpus) {
|
|
|
|
cluster.fork();
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
const proxyworkerMod = await import('./smartproxy.classes.proxyworker');
|
|
|
|
const proxyWorkerInstance = new proxyworkerMod.ProxyWorker();
|
|
|
|
console.log('Proxymaster registered a ProxyWorker!');
|
|
|
|
const data = new Uint8Array(Buffer.from('Hello Node.js'));
|
|
|
|
fs.writeFile('message.txt', data, (err) => {
|
|
|
|
if (err) throw err;
|
|
|
|
console.log('The file has been saved!');
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
2019-08-22 12:49:29 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
const defaultProxyMaster = new ProxyMaster();
|
2019-08-22 13:20:41 +02:00
|
|
|
if (!cluster.isMaster) {
|
|
|
|
defaultProxyMaster.start();
|
|
|
|
}
|
|
|
|
console.log('hi');
|
2019-08-22 12:49:29 +02:00
|
|
|
|
2019-08-22 13:20:41 +02:00
|
|
|
// the following is interesting for the master process only
|
2019-08-22 12:49:29 +02:00
|
|
|
const proxyMasterCalls = {
|
|
|
|
terminateMaster: async () => {
|
|
|
|
process.kill(0);
|
|
|
|
},
|
2019-08-22 13:20:41 +02:00
|
|
|
start: async () => {
|
|
|
|
await defaultProxyMaster.start();
|
|
|
|
},
|
|
|
|
updateReverseConfigs: async (configArray: plugins.tsclass.network.IReverseProxyConfig[]) => {
|
|
|
|
|
|
|
|
}
|
2019-08-22 12:49:29 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
export type TProxyMasterCalls = typeof proxyMasterCalls;
|
|
|
|
expose (proxyMasterCalls);
|