From 65e462858e957a94876b6941cc62a1b494567b2f Mon Sep 17 00:00:00 2001 From: Evan Prodromou Date: Tue, 2 Sep 2008 13:17:40 -0400 Subject: set the reconnect timeout darcs-hash:20080902171740-84dde-ee629f4b5dbcf712cd350c37d0f1814ca1b7f237.gz --- extlib/XMPPHP/XMLStream.php | 14 ++++++++++++-- 1 file changed, 12 insertions(+), 2 deletions(-) (limited to 'extlib/XMPPHP') diff --git a/extlib/XMPPHP/XMLStream.php b/extlib/XMPPHP/XMLStream.php index e59e95902..b27811407 100644 --- a/extlib/XMPPHP/XMLStream.php +++ b/extlib/XMPPHP/XMLStream.php @@ -153,6 +153,10 @@ class XMPPHP_XMLStream { * @var boolean */ protected $use_ssl = false; + /** + * @var integer + */ + protected $reconnect = 30; /** * Constructor @@ -274,6 +278,8 @@ class XMPPHP_XMLStream { if(!$this->socket) { $this->log->log("Could not connect.", XMPPHP_Log::LEVEL_ERROR); $this->disconnected = true; + # Take it easy for a few seconds + sleep(min($timeout, 5)); } } while (!$this->socket && (time() - $starttime) < $timeout); @@ -290,13 +296,17 @@ class XMPPHP_XMLStream { */ public function doReconnect() { if(!$this->is_server) { - $this->log->log("Reconnecting...", XMPPHP_Log::LEVEL_WARNING); - $this->connect(30, false, false); + $this->log->log("Reconnecting ($this->reconnect)...", XMPPHP_Log::LEVEL_WARNING); + $this->connect($this->reconnect, false, false); $this->reset(); $this->event('reconnect'); } } + public function reconnectTimeout($timeout) { + $this->reconnect = $timeout; + } + /** * Disconnect from XMPP Host */ -- cgit v1.2.3-54-g00ecf