|
|
|
@ -250,28 +250,44 @@ JNj2Dr5H0XoLFFnvuvzcRbhlJ9J67JzR+7g=
|
|
|
|
|
console.log(`wss proxy: got connection for wsc for https://${reqArg.headers.host}${reqArg.url}`);
|
|
|
|
|
|
|
|
|
|
let wsOutgoing: plugins.wsDefault;
|
|
|
|
|
|
|
|
|
|
const outGoingDeferred = plugins.smartpromise.defer();
|
|
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
wsOutgoing = new plugins.wsDefault(`ws://${this.router.routeReq(reqArg).destinationIp}:${this.router.routeReq(reqArg).destinationPort}${reqArg.url}`);
|
|
|
|
|
console.log('wss proxy: initiated outgoing proxy')
|
|
|
|
|
console.log('wss proxy: initiated outgoing proxy');
|
|
|
|
|
wsOutgoing.on('open', async () => {
|
|
|
|
|
outGoingDeferred.resolve();
|
|
|
|
|
})
|
|
|
|
|
} catch (err) {
|
|
|
|
|
console.log(err);
|
|
|
|
|
wsIncoming.terminate();
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
wsIncoming.on("message", (message, isBinary) => {
|
|
|
|
|
wsIncoming.on("message", async (message, isBinary) => {
|
|
|
|
|
await outGoingDeferred.promise;
|
|
|
|
|
// console.log("client to upstream", message);
|
|
|
|
|
wsOutgoing.send(message, { binary: isBinary });
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
wsOutgoing.on("message", (message, isBinary) => {
|
|
|
|
|
wsOutgoing.on("message", async (message, isBinary) => {
|
|
|
|
|
// console.log("upstream to client", message);
|
|
|
|
|
wsIncoming.send(message, { binary: isBinary });
|
|
|
|
|
});
|
|
|
|
|
wsIncoming.on("error", () => wsOutgoing.terminate());
|
|
|
|
|
wsOutgoing.on("error", () => wsIncoming.terminate());
|
|
|
|
|
wsIncoming.on("close", () => wsOutgoing.terminate());
|
|
|
|
|
wsOutgoing.on("close", () => wsIncoming.terminate());
|
|
|
|
|
const terminateWsOutgoing = () => {
|
|
|
|
|
wsOutgoing.terminate();
|
|
|
|
|
console.log('terminated outgoing ws.');
|
|
|
|
|
}
|
|
|
|
|
wsIncoming.on("error", () => terminateWsOutgoing());
|
|
|
|
|
wsIncoming.on("close", () => terminateWsOutgoing());
|
|
|
|
|
|
|
|
|
|
const terminateWsIncoming = () => {
|
|
|
|
|
wsIncoming.terminate();
|
|
|
|
|
console.log('terminated incoming ws.');
|
|
|
|
|
}
|
|
|
|
|
wsOutgoing.on("error", () => terminateWsIncoming());
|
|
|
|
|
wsOutgoing.on("close", () => terminateWsIncoming());
|
|
|
|
|
|
|
|
|
|
});
|
|
|
|
|
this.httpsServer.keepAliveTimeout = 600 * 1000;
|
|
|
|
|