ssh: Support specifying the port too.

wip-fakessh-exit-status
David Wilson 7 years ago
parent bdf4fcfbce
commit 559b88ff12

@ -13,10 +13,14 @@ class Stream(mitogen.master.Stream):
#: The path to the SSH binary. #: The path to the SSH binary.
ssh_path = 'ssh' ssh_path = 'ssh'
def construct(self, hostname, username=None, ssh_path=None, **kwargs): port = None
def construct(self, hostname, username=None, ssh_path=None, port=None,
**kwargs):
super(Stream, self).construct(**kwargs) super(Stream, self).construct(**kwargs)
self.hostname = hostname self.hostname = hostname
self.username = username self.username = username
self.port = port
if ssh_path: if ssh_path:
self.ssh_path = ssh_path self.ssh_path = ssh_path
@ -24,6 +28,8 @@ class Stream(mitogen.master.Stream):
bits = [self.ssh_path] bits = [self.ssh_path]
if self.username: if self.username:
bits += ['-l', self.username] bits += ['-l', self.username]
if self.port is not None:
bits += ['-p', str(self.port)]
bits.append(self.hostname) bits.append(self.hostname)
base = super(Stream, self).get_boot_command() base = super(Stream, self).get_boot_command()
return bits + map(commands.mkarg, base) return bits + map(commands.mkarg, base)
@ -31,3 +37,5 @@ class Stream(mitogen.master.Stream):
def connect(self): def connect(self):
super(Stream, self).connect() super(Stream, self).connect()
self.name = 'ssh.' + self.hostname self.name = 'ssh.' + self.hostname
if self.port:
self.name += ':%s' % (self.port,)

Loading…
Cancel
Save