Sophie

Sophie

distrib > Fedora > 15 > i386 > by-pkgid > 7f1868553cf1a8b545b15db6d6ec9eb4 > files > 3

ejabberd-2.1.6-4.fc15.src.rpm

From cf4847224a1180836d1caee3621ff0d562e4e8a7 Mon Sep 17 00:00:00 2001
From: Sergei Golovan <sgolovan@nes.ru>
Date: Tue, 16 Feb 2010 16:07:37 +0300
Subject: [PATCH 03/11] Fixed delays in s2s connections.

Patch by Sergei Golovan increases timeouts in S2S and removes horrible 5-minute
delay between remote server connection attempts after a falure (in case of
server is down it would be reasonable, but what happens much more often is a
network split when the delay is inadmissible).
---
 src/ejabberd_s2s_in.erl  |    2 +-
 src/ejabberd_s2s_out.erl |    5 +++--
 2 files changed, 4 insertions(+), 3 deletions(-)

diff --git a/src/ejabberd_s2s_in.erl b/src/ejabberd_s2s_in.erl
index eb8c05a..0ab9d94 100644
--- a/src/ejabberd_s2s_in.erl
+++ b/src/ejabberd_s2s_in.erl
@@ -404,7 +404,7 @@ stream_established({xmlstreamelement, El}, StateData) ->
             case {ejabberd_s2s:allow_host(LTo, LFrom),
                   lists:member(LTo, ejabberd_router:dirty_get_all_domains())} of
                 {true, true} ->
-		    ejabberd_s2s_out:terminate_if_waiting_delay(LTo, LFrom),
+		    %%ejabberd_s2s_out:terminate_if_waiting_delay(LTo, LFrom),
 		    ejabberd_s2s_out:start(LTo, LFrom,
 					   {verify, self(),
 					    Key, StateData#state.streamid}),
diff --git a/src/ejabberd_s2s_out.erl b/src/ejabberd_s2s_out.erl
index f59e8ec..1422d3a 100644
--- a/src/ejabberd_s2s_out.erl
+++ b/src/ejabberd_s2s_out.erl
@@ -93,7 +93,7 @@
 						 [From, Host, Type])).
 -endif.
 
--define(FSMTIMEOUT, 30000).
+-define(FSMTIMEOUT, 60000).
 
 %% We do not block on send anymore.
 -define(TCP_SEND_TIMEOUT, 15000).
@@ -245,7 +245,8 @@ open_socket(init, StateData) ->
 		    NewStateData = StateData#state{bridge={Mod, Fun}},
 		    {next_state, relay_to_bridge, NewStateData};
 		_ ->
-		    wait_before_reconnect(StateData)
+		    %%wait_before_reconnect(StateData)
+		    {stop, normal, StateData}
 	    end
     end;
 open_socket(stop, StateData) ->
-- 
1.7.4.1