start(SockData, Opts) ->
case proplists:get_value(supervisor, Opts, true) of
true ->
- supervisor:start_child(ejabberd_c2s_sup, [SockData, Opts]);
+ case supervisor:start_child(ejabberd_c2s_sup, [SockData, Opts]) of
+ {ok, undefined} -> ignore;
+ Res -> Res
+ end;
_ ->
xmpp_stream_in:start(?MODULE, [SockData, Opts],
ejabberd_config:fsm_limit_opts(Opts))
start(SockData, Opts) ->
case proplists:get_value(supervisor, Opts, true) of
true ->
- supervisor:start_child(ejabberd_s2s_in_sup, [SockData, Opts]);
+ case supervisor:start_child(ejabberd_s2s_in_sup, [SockData, Opts]) of
+ {ok, undefined} -> ignore;
+ Res -> Res
+ end;
_ ->
xmpp_stream_in:start(?MODULE, [SockData, Opts],
ejabberd_config:fsm_limit_opts(Opts))
%%%===================================================================
start(From, To, Opts) ->
case proplists:get_value(supervisor, Opts, true) of
- true ->
- supervisor:start_child(ejabberd_s2s_out_sup,
- [From, To, Opts]);
- _ ->
+ true ->
+ case supervisor:start_child(ejabberd_s2s_out_sup,
+ [From, To, Opts]) of
+ {ok, undefined} -> ignore;
+ Res -> Res
+ end;
+ _ ->
xmpp_stream_out:start(?MODULE, [ejabberd_socket, From, To, Opts],
ejabberd_config:fsm_limit_opts([]))
end.
%% API
%%====================================================================
-spec start(atom(), sockmod(), socket(), [proplists:property()])
- -> {ok, pid() | independent} | {error, inet:posix() | any()}.
+ -> {ok, pid() | independent} | {error, inet:posix() | any()} | ignore.
start(Module, SockMod, Socket, Opts) ->
case Module:socket_type() of
independent -> {ok, independent};