-
Notifications
You must be signed in to change notification settings - Fork 671
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
François Leurent
committed
Jun 25, 2021
1 parent
27795a3
commit 40fa58f
Showing
3 changed files
with
41 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -1284,6 +1284,12 @@ class Client extends EventEmitter { | |
return this; | ||
} | ||
|
||
|
||
openssh_authAgent(cb) { | ||
openChannel(this, '[email protected]', cb); | ||
return this; | ||
} | ||
|
||
openssh_forwardOutStreamLocal(socketPath, cb) { | ||
const opts = { socketPath }; | ||
openChannel(this, '[email protected]', opts, cb); | ||
|
@@ -1341,6 +1347,9 @@ function openChannel(self, type, opts, cb) { | |
case 'x11': | ||
self._protocol.x11(localChan, initWindow, maxPacket, opts); | ||
break; | ||
case '[email protected]': | ||
self._protocol.openssh_authAgent(localChan, initWindow, maxPacket); | ||
break; | ||
case '[email protected]': | ||
self._protocol.openssh_forwardedStreamLocal( | ||
localChan, initWindow, maxPacket, opts | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -2,6 +2,7 @@ | |
|
||
const assert = require('assert'); | ||
const { inspect } = require('util'); | ||
const { spawn } = require('child_process'); | ||
|
||
const { | ||
fixture, | ||
|
@@ -12,16 +13,27 @@ const { | |
|
||
const debug = false; | ||
|
||
const test_forward = (process.platform !== 'win32'); | ||
|
||
if (!test_forward) | ||
console.log('Skipping agent forwarding test on Windows'); | ||
|
||
|
||
const clientCfg = { username: 'foo', password: 'bar' }; | ||
const serverCfg = { hostKeys: [ fixture('ssh_host_rsa_key') ] }; | ||
|
||
{ | ||
const agent_sock = '/tmp/nodejs-ssh2-test-' + process.pid; | ||
let agent; | ||
if (test_forward) | ||
agent = spawn('ssh-agent', ['-d', '-a', agent_sock]); | ||
|
||
const { client, server } = setup_( | ||
'Exec with OpenSSH agent forwarding', | ||
{ | ||
client: { | ||
...clientCfg, | ||
agent: '/path/to/agent', | ||
agent: agent_sock, | ||
}, | ||
server: serverCfg, | ||
|
||
|
@@ -45,8 +57,23 @@ const serverCfg = { hostKeys: [ fixture('ssh_host_rsa_key') ] }; | |
const stream = accept(); | ||
stream.exit(100); | ||
stream.end(); | ||
conn.end(); | ||
|
||
if (test_forward) { | ||
conn.openssh_authAgent(function(err, stream) { | ||
assert(!err, `Unexpected openssh_authAgent error: ${err}`); | ||
assert(stream.type === '[email protected]', | ||
`Unexpected openssh_authAgent channel type : ${stream.type}`); | ||
|
||
conn.end(); | ||
agent.kill(); | ||
}); | ||
|
||
} else { | ||
conn.end(); | ||
} | ||
|
||
})); | ||
|
||
})); | ||
})); | ||
})); | ||
|