mirror of
https://github.com/processone/ejabberd.git
synced 2024-11-22 16:20:52 +01:00
Use a function to convert to old structures instead of duplicating code
inside the module. SVN Revision: 1400
This commit is contained in:
parent
b08ae07347
commit
6f7cf2e58b
@ -23,6 +23,9 @@
|
|||||||
* src/ejabberd_c2s.erl, src/ejabberd_s2s_in.erl: acl doesn't require
|
* src/ejabberd_c2s.erl, src/ejabberd_s2s_in.erl: acl doesn't require
|
||||||
conversion anymore.
|
conversion anymore.
|
||||||
|
|
||||||
|
* src/ejabberd_router.erl: Use a function to convert to old
|
||||||
|
structures instead of duplicating code inside the module.
|
||||||
|
|
||||||
2008-06-30 Jean-Sébastien Pédron <js.pedron@meetic-corp.com>
|
2008-06-30 Jean-Sébastien Pédron <js.pedron@meetic-corp.com>
|
||||||
|
|
||||||
* src/Makefile.in: Remove the -I flag for exmpp includes; the
|
* src/Makefile.in: Remove the -I flag for exmpp includes; the
|
||||||
|
@ -66,25 +66,7 @@ start_link() ->
|
|||||||
|
|
||||||
route(From, To, Packet) ->
|
route(From, To, Packet) ->
|
||||||
% XXX OLD FORMAT: This code helps to detect old format routing.
|
% XXX OLD FORMAT: This code helps to detect old format routing.
|
||||||
{FromOld, ToOld, PacketOld} = case Packet of
|
{FromOld, ToOld, PacketOld} = convert_to_old_structs(From, To, Packet),
|
||||||
#xmlelement{} ->
|
|
||||||
catch throw(for_stacktrace), % To have a stacktrace.
|
|
||||||
io:format("~nROUTE: old #xmlelement:~n~p~n~p~n~n",
|
|
||||||
[Packet, erlang:get_stacktrace()]),
|
|
||||||
{From, To, Packet};
|
|
||||||
_ ->
|
|
||||||
F = jlib:to_old_jid(From),
|
|
||||||
T = jlib:to_old_jid(To),
|
|
||||||
Default_NS = case lists:member({Packet#xmlel.ns, none},
|
|
||||||
Packet#xmlel.declared_ns) of
|
|
||||||
true -> [];
|
|
||||||
false -> [Packet#xmlel.ns]
|
|
||||||
end,
|
|
||||||
P = exmpp_xml:xmlel_to_xmlelement(Packet,
|
|
||||||
Default_NS,
|
|
||||||
[{?NS_XMPP, ?NS_XMPP_pfx}, {?NS_DIALBACK, ?NS_DIALBACK_pfx}]),
|
|
||||||
{F, T, P}
|
|
||||||
end,
|
|
||||||
case catch do_route(FromOld, ToOld, PacketOld) of
|
case catch do_route(FromOld, ToOld, PacketOld) of
|
||||||
{'EXIT', Reason} ->
|
{'EXIT', Reason} ->
|
||||||
?ERROR_MSG("~p~nwhen processing: ~p",
|
?ERROR_MSG("~p~nwhen processing: ~p",
|
||||||
@ -258,26 +240,7 @@ handle_cast(_Msg, State) ->
|
|||||||
%% Description: Handling all non call/cast messages
|
%% Description: Handling all non call/cast messages
|
||||||
%%--------------------------------------------------------------------
|
%%--------------------------------------------------------------------
|
||||||
handle_info({route, From, To, Packet}, State) ->
|
handle_info({route, From, To, Packet}, State) ->
|
||||||
% XXX OLD FORMAT: This code helps to detect old format routing.
|
{FromOld, ToOld, PacketOld} = convert_to_old_structs(From, To, Packet),
|
||||||
{FromOld, ToOld, PacketOld} = case Packet of
|
|
||||||
#xmlelement{} ->
|
|
||||||
catch throw(for_stacktrace), % To have a stacktrace.
|
|
||||||
io:format("~nROUTE: old #xmlelement:~n~p~n~p~n~n",
|
|
||||||
[Packet, erlang:get_stacktrace()]),
|
|
||||||
{From, To, Packet};
|
|
||||||
_ ->
|
|
||||||
F = jlib:to_old_jid(From),
|
|
||||||
T = jlib:to_old_jid(To),
|
|
||||||
Default_NS = case lists:member({Packet#xmlel.ns, none},
|
|
||||||
Packet#xmlel.declared_ns) of
|
|
||||||
true -> [];
|
|
||||||
false -> [Packet#xmlel.ns]
|
|
||||||
end,
|
|
||||||
P = exmpp_xml:xmlel_to_xmlelement(Packet,
|
|
||||||
Default_NS,
|
|
||||||
[{?NS_XMPP, ?NS_XMPP_pfx}, {?NS_DIALBACK, ?NS_DIALBACK_pfx}]),
|
|
||||||
{F, T, P}
|
|
||||||
end,
|
|
||||||
case catch do_route(FromOld, ToOld, PacketOld) of
|
case catch do_route(FromOld, ToOld, PacketOld) of
|
||||||
{'EXIT', Reason} ->
|
{'EXIT', Reason} ->
|
||||||
?ERROR_MSG("~p~nwhen processing: ~p",
|
?ERROR_MSG("~p~nwhen processing: ~p",
|
||||||
@ -443,3 +406,24 @@ update_tables() ->
|
|||||||
ok
|
ok
|
||||||
end.
|
end.
|
||||||
|
|
||||||
|
convert_to_old_structs(From, To, Packet) ->
|
||||||
|
% XXX OLD FORMAT: This code helps to detect old format routing.
|
||||||
|
if
|
||||||
|
is_record(Packet, xmlelement) ->
|
||||||
|
catch throw(for_stacktrace), % To have a stacktrace.
|
||||||
|
io:format("~nROUTE: old #xmlelement:~n~p~n~p~n~n",
|
||||||
|
[Packet, erlang:get_stacktrace()]),
|
||||||
|
{From, To, Packet};
|
||||||
|
true ->
|
||||||
|
F = jlib:to_old_jid(From),
|
||||||
|
T = jlib:to_old_jid(To),
|
||||||
|
Default_NS = case lists:member({Packet#xmlel.ns, none},
|
||||||
|
Packet#xmlel.declared_ns) of
|
||||||
|
true -> [];
|
||||||
|
false -> [Packet#xmlel.ns]
|
||||||
|
end,
|
||||||
|
P = exmpp_xml:xmlel_to_xmlelement(Packet,
|
||||||
|
Default_NS,
|
||||||
|
[{?NS_XMPP, ?NS_XMPP_pfx}, {?NS_DIALBACK, ?NS_DIALBACK_pfx}]),
|
||||||
|
{F, T, P}
|
||||||
|
end.
|
||||||
|
Loading…
Reference in New Issue
Block a user