From 8c3043b4b55b7a313deb9d84e6e83d36eff032a4 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Fran=C3=A7ois=20Leurent?= <131.js@cloudyks.org> Date: Sat, 20 Apr 2019 13:56:33 +0200 Subject: [PATCH] Add server-side auth-agent --- README.md | 2 ++ lib/server.js | 7 +++++++ 2 files changed, 9 insertions(+) diff --git a/README.md b/README.md index 2807bbbf..dadadea3 100644 --- a/README.md +++ b/README.md @@ -900,6 +900,8 @@ You can find more examples in the `examples` directory of this repository. * **forwardOut**(< _string_ >boundAddr, < _integer_ >boundPort, < _string_ >remoteAddr, < _integer_ >remotePort, < _function_ >callback) - _boolean_ - Alert the client of an incoming TCP connection on `boundAddr` on port `boundPort` from `remoteAddr` on port `remotePort`. `callback` has 2 parameters: < _Error_ >err, < _Channel_ >stream. Returns `false` if you should wait for the `continue` event before sending any more traffic. +* **openssh_authAgent**(< _function_ >callback) - _boolean_ - Alert the client of an incoming `ssh-agent` socket connection. `callback` has 2 parameters: < _Error_ >err, < _Channel_ >stream. Returns `false` if you should wait for the `continue` event before sending any more traffic. + * **openssh_forwardOutStreamLocal**(< _string_ >socketPath, < _function_ >callback) - _boolean_ - Alert the client of an incoming UNIX domain socket connection on `socketPath`. `callback` has 2 parameters: < _Error_ >err, < _Channel_ >stream. Returns `false` if you should wait for the `continue` event before sending any more traffic. * **rekey**([< _function_ >callback]) - _boolean_ - Initiates a rekeying with the client. If `callback` is supplied, it is added as a one-time handler for the `rekey` event. Returns `false` if you should wait for the `continue` event before sending any more traffic. diff --git a/lib/server.js b/lib/server.js index 36a066d4..2c30a206 100644 --- a/lib/server.js +++ b/lib/server.js @@ -646,6 +646,11 @@ Client.prototype.forwardOut = function(boundAddr, boundPort, remoteAddr, return openChannel(this, 'forwarded-tcpip', opts, cb); }; +Client.prototype.openssh_authAgent = function(cb) { + var opts = {}; + return openChannel(this, 'auth-agent@openssh.com', opts, cb); +}; + Client.prototype.openssh_forwardOutStreamLocal = function(socketPath, cb) { var opts = { socketPath: socketPath @@ -1121,6 +1126,8 @@ function openChannel(self, type, opts, cb) { ret = sshstream.forwardedTcpip(localChan, initWindow, maxPacket, opts); else if (type === 'x11') ret = sshstream.x11(localChan, initWindow, maxPacket, opts); + else if(type == "auth-agent@openssh.com") + ret = sshstream.openssh_authAgent(localChan, initWindow, maxPacket); else if (type === 'forwarded-streamlocal@openssh.com') { ret = sshstream.openssh_forwardedStreamLocal(localChan, initWindow,