diff options
author | Evan Prodromou <evan@prodromou.name> | 2008-09-02 13:17:40 -0400 |
---|---|---|
committer | Evan Prodromou <evan@prodromou.name> | 2008-09-02 13:17:40 -0400 |
commit | 65e462858e957a94876b6941cc62a1b494567b2f (patch) | |
tree | 9b6a0c8d3a2e6f78a69c3c404afee579457890a9 /extlib/XMPPHP | |
parent | af8e38aeff0548b3e4f7997c56c8b3c7a3ef79e0 (diff) |
set the reconnect timeout
darcs-hash:20080902171740-84dde-ee629f4b5dbcf712cd350c37d0f1814ca1b7f237.gz
Diffstat (limited to 'extlib/XMPPHP')
-rw-r--r-- | extlib/XMPPHP/XMLStream.php | 14 |
1 files changed, 12 insertions, 2 deletions
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 */ |