bdy 1.9.50-dev → 1.9.51-dev
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/distTs/package.json +1 -1
- package/distTs/src/server/ssh.js +49 -0
- package/package.json +1 -1
package/distTs/package.json
CHANGED
package/distTs/src/server/ssh.js
CHANGED
|
@@ -326,6 +326,23 @@ class ServerSsh extends events_1.default {
|
|
|
326
326
|
client.setNoDelay();
|
|
327
327
|
client.on('authentication', async (ctx) => {
|
|
328
328
|
proxyClient = await this.authenticateClient(ctx);
|
|
329
|
+
if (proxyClient) {
|
|
330
|
+
proxyClient.on('tcp connection', (details, accept, reject) => {
|
|
331
|
+
logger_js_1.default.debug('new ssh client forward connection');
|
|
332
|
+
logger_js_1.default.debug(details);
|
|
333
|
+
const { destIP, destPort, srcIP, srcPort } = details;
|
|
334
|
+
client.forwardOut(destIP, destPort, srcIP, srcPort, (err, channel) => {
|
|
335
|
+
logger_js_1.default.debug('new ssh client forward out connection');
|
|
336
|
+
logger_js_1.default.debug({ destIP, destPort, srcIP, srcPort });
|
|
337
|
+
if (err) {
|
|
338
|
+
reject();
|
|
339
|
+
return;
|
|
340
|
+
}
|
|
341
|
+
const stream = accept();
|
|
342
|
+
channel.pipe(stream).pipe(channel);
|
|
343
|
+
});
|
|
344
|
+
});
|
|
345
|
+
}
|
|
329
346
|
logger_js_1.default.debug('ssh authentication', !!proxyClient);
|
|
330
347
|
});
|
|
331
348
|
client.on('close', () => {
|
|
@@ -345,6 +362,38 @@ class ServerSsh extends events_1.default {
|
|
|
345
362
|
client = null;
|
|
346
363
|
}, 1000);
|
|
347
364
|
});
|
|
365
|
+
client.on('request', (accept, reject, name, info) => {
|
|
366
|
+
logger_js_1.default.debug('ssh forward request');
|
|
367
|
+
logger_js_1.default.debug(name);
|
|
368
|
+
logger_js_1.default.debug(info);
|
|
369
|
+
if (!proxyClient) {
|
|
370
|
+
reject();
|
|
371
|
+
return;
|
|
372
|
+
}
|
|
373
|
+
if (name === 'tcpip-forward') {
|
|
374
|
+
let { bindAddr, bindPort } = info;
|
|
375
|
+
proxyClient.forwardIn(bindAddr, bindPort, (err, port) => {
|
|
376
|
+
if (err) {
|
|
377
|
+
reject();
|
|
378
|
+
return;
|
|
379
|
+
}
|
|
380
|
+
accept(port);
|
|
381
|
+
});
|
|
382
|
+
return;
|
|
383
|
+
}
|
|
384
|
+
if (name === 'cancel-tcpip-forward') {
|
|
385
|
+
const { bindAddr, bindPort } = info;
|
|
386
|
+
proxyClient.unforwardIn(bindAddr, bindPort, (err) => {
|
|
387
|
+
if (err) {
|
|
388
|
+
reject();
|
|
389
|
+
return;
|
|
390
|
+
}
|
|
391
|
+
accept();
|
|
392
|
+
});
|
|
393
|
+
return;
|
|
394
|
+
}
|
|
395
|
+
reject();
|
|
396
|
+
});
|
|
348
397
|
client.on('error', (err) => {
|
|
349
398
|
logger_js_1.default.debug('Error on ssh server client');
|
|
350
399
|
logger_js_1.default.debug(err);
|