[Twisted-Python] help with ssl timeout and not reconnecting client factory

Andrea Arcangeli andrea at cpushare.com
Thu Mar 17 17:58:55 EST 2005


On Thu, Mar 17, 2005 at 11:51:04AM -0500, Itamar Shtull-Trauring wrote:
> There was a bug in 1.3 in ReconnectingClientFactory that caused it to
> not reconnect on TimeoutErrors. It's fixed in 2.0.

Ok. This should workaround the bug in my app:

Index: cpushare/proto.py
===================================================================
RCS file: /home/andrea/crypto/cvs/cpushare/client/cpushare/cpushare/proto.py,v
retrieving revision 1.29
diff -u -p -r1.29 proto.py
--- cpushare/proto.py	13 Mar 2005 23:18:24 -0000	1.29
+++ cpushare/proto.py	17 Mar 2005 22:56:20 -0000
@@ -148,8 +148,24 @@ class cpushare_factory(ReconnectingClien
 		protocol.factory = self
 		return protocol
 
+	def clientConnectionLost(self, connector, reason):
+		print 'Lost connection. Reason:', reason
+		ReconnectingClientFactory.clientConnectionLost(self, connector, reason)
+
 	def clientConnectionFailed(self, connector, reason):
 		print 'Connection failed. Reason:', reason
+		# workaround for bug in 1.3.0 - start
+		from twisted.copyright import version
+		if '1.3.0' in version:
+			def workaround_clientConnectionFailed(connector, reason):
+				if self.continueTrying:
+					self.connector = connector
+					from twisted.internet import interfaces, error, defer
+					if not reason.check(error.UserError) or reason.check(defer.TimeoutError):
+						self.retry()
+			workaround_clientConnectionFailed(connector, reason)
+			return
+		# workaround for bug in 1.3.0 - end
 		ReconnectingClientFactory.clientConnectionFailed(self, connector, reason)
 
 	def connectionMade(self):


Thanks Itamar and Jp for the help!




More information about the Twisted-Python mailing list