summaryrefslogtreecommitdiff
path: root/extlib/XMPPHP
diff options
context:
space:
mode:
authorEvan Prodromou <evan@prodromou.name>2008-09-02 13:17:40 -0400
committerEvan Prodromou <evan@prodromou.name>2008-09-02 13:17:40 -0400
commit65e462858e957a94876b6941cc62a1b494567b2f (patch)
tree9b6a0c8d3a2e6f78a69c3c404afee579457890a9 /extlib/XMPPHP
parentaf8e38aeff0548b3e4f7997c56c8b3c7a3ef79e0 (diff)
set the reconnect timeout
darcs-hash:20080902171740-84dde-ee629f4b5dbcf712cd350c37d0f1814ca1b7f237.gz
Diffstat (limited to 'extlib/XMPPHP')
-rw-r--r--extlib/XMPPHP/XMLStream.php14
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
*/