From 9d277627203f7efb67a664227a06355edaa49449 Mon Sep 17 00:00:00 2001 From: Robey Pointer Date: Sun, 3 Jul 2005 01:26:35 +0000 Subject: [project @ Arch-1:robey@lag.net--2005-master-shake%paramiko--dev--1--patch-22] some doc changes; catch socket.error in the transport thread and log it as such instead of as an 'unknown exception' --- paramiko/transport.py | 23 +++++++++++++++++++++-- 1 file changed, 21 insertions(+), 2 deletions(-) diff --git a/paramiko/transport.py b/paramiko/transport.py index 23df086d..d72fb20f 100644 --- a/paramiko/transport.py +++ b/paramiko/transport.py @@ -356,7 +356,8 @@ class BaseTransport (threading.Thread): as a server, the host key is used to sign certain packets during the SSH2 negotiation, so that the client can trust that we are who we say we are. Because this is used for signing, the key must contain private - key info, not just the public half. + key info, not just the public half. Only one key of each type (RSA or + DSS) is kept. @param key: the host key to add, usually an L{RSAKey } or L{DSSKey }. @@ -559,7 +560,7 @@ class BaseTransport (threading.Thread): firewalls. @param bytes: the number of random bytes to send in the payload of the - ignored packet -- defaults to a random number from 10 to 41. + ignored packet -- defaults to a random number from 10 to 41. @type bytes: int @since: fearow @@ -653,6 +654,17 @@ class BaseTransport (threading.Thread): return self.global_response def accept(self, timeout=None): + """ + Return the next channel opened by the client over this transport, in + server mode. If no channel is opened before the given timeout, C{None} + is returned. + + @param timeout: seconds to wait for a channel, or C{None} to wait + forever + @type timeout: int + @return: a new Channel opened by the client + @rtype: L{Channel} + """ self.lock.acquire() try: if len(self.server_accepts) > 0: @@ -979,6 +991,13 @@ class BaseTransport (threading.Thread): self._log(DEBUG, 'EOF in transport thread') #self._log(DEBUG, util.tb_strings()) self.saved_exception = e + except socket.error, e: + if type(e.args) is tuple: + emsg = '%s (%d)' % (e.args[1], e.args[0]) + else: + emsg = e.args + self._log(ERROR, 'Socket exception: ' + emsg) + self.saved_exception = e except Exception, e: self._log(ERROR, 'Unknown exception: ' + str(e)) self._log(ERROR, util.tb_strings()) -- cgit v1.2.3