Fix mod_webpresence to work with recent ejabberd (#232)

This commit is contained in:
Badlop 2018-08-21 12:27:44 +02:00
parent b7b6af8315
commit f20d6239db
1 changed files with 15 additions and 18 deletions

View File

@ -240,7 +240,7 @@ process_vcard(#iq{lang = Lang} = IQ) ->
xmpp:make_error(IQ, xmpp:err_service_unavailable(Txt, Lang)). xmpp:make_error(IQ, xmpp:err_service_unavailable(Txt, Lang)).
do_route1(_Host, _From, _To, #iq{} = IQ, _BaseURL) -> do_route1(_Host, _From, _To, #iq{} = IQ, _BaseURL) ->
ejabberd_local:process_iq(IQ); ejabberd_router:process_iq(IQ);
do_route1(_Host, _From, _To, Packet, _BaseURL) -> do_route1(_Host, _From, _To, Packet, _BaseURL) ->
case xmpp:get_type(Packet) of case xmpp:get_type(Packet) of
error -> ok; error -> ok;
@ -254,7 +254,6 @@ do_route1(_Host, _From, _To, Packet, _BaseURL) ->
process_register(#iq{type = get, from = From, to = To, lang = Lang, process_register(#iq{type = get, from = From, to = To, lang = Lang,
sub_els = [#register{}]} = IQ) -> sub_els = [#register{}]} = IQ) ->
Host = To#jid.lserver, Host = To#jid.lserver,
ServerHost = ejabberd_router:host_of_route(Host),
xmpp:make_iq_result(IQ, iq_get_register_info(Host, From, Lang)); xmpp:make_iq_result(IQ, iq_get_register_info(Host, From, Lang));
process_register(#iq{type = set, from = From, to = To, process_register(#iq{type = set, from = From, to = To,
lang = Lang, sub_els = [El = #register{}]} = IQ) -> lang = Lang, sub_els = [El = #register{}]} = IQ) ->
@ -368,7 +367,7 @@ iq_get_register_info(Host, From, Lang) ->
"to register to Web Presence">>), "to register to Web Presence">>),
xdata = X}. xdata = X}.
process_iq_register_set(ServerHost, Host, From, process_iq_register_set(_ServerHost, Host, From,
#register{remove = true}, Lang) -> #register{remove = true}, Lang) ->
unregister_webpresence(From, Host, Lang); unregister_webpresence(From, Host, Lang);
process_iq_register_set(_ServerHost, _Host, _From, process_iq_register_set(_ServerHost, _Host, _From,
@ -410,14 +409,13 @@ iq_set_register_info(ServerHost, Host, From, Nick,
end. end.
iq_set_register_info2(ServerHost, Host, From, Icon, Lang) -> iq_set_register_info2(ServerHost, Host, From, Icon, Lang) ->
LServer = jid:nameprep(ServerHost),
%% RidUrl2 = get_rid_final_value(RidUrl, LUS), %% RidUrl2 = get_rid_final_value(RidUrl, LUS),
LUS = {From#jid.luser, From#jid.lserver}, LUS = {From#jid.luser, From#jid.lserver},
WP = #webpresence{us = LUS, WP = #webpresence{us = LUS,
jidurl = true, jidurl = true,
ridurl = false, ridurl = false,
xml = true, xml = true,
avatar = false, avatar = true,
js = true, js = true,
text = true, text = true,
icon = Icon}, icon = Icon},
@ -433,8 +431,7 @@ iq_set_register_info2(ServerHost, Host, From, Icon, Lang) ->
send_message_registered(WP, To, Host, BaseURL, Lang) -> send_message_registered(WP, To, Host, BaseURL, Lang) ->
{User, Server} = WP#webpresence.us, {User, Server} = WP#webpresence.us,
JID = jlib:make_jid(User, Server, <<"">>), JIDS = jid:encode({User, Server, <<"">>}),
JIDS = jlib:jid_to_string(JID),
Oavatar = case WP#webpresence.avatar of Oavatar = case WP#webpresence.avatar of
false -> <<"">>; false -> <<"">>;
true -> <<" avatar\n" true -> <<" avatar\n"
@ -509,7 +506,7 @@ send_message_unregistered(To, Host, Lang) ->
send_headline(Host, To, Subject, Body) -> send_headline(Host, To, Subject, Body) ->
ejabberd_router:route( ejabberd_router:route(
jlib:make_jid(<<"">>, Host, <<"">>), jid:make(<<"">>, Host, <<"">>),
To, To,
#xmlel{ #xmlel{
name = <<"message">>, name = <<"message">>,
@ -548,7 +545,7 @@ get_wp(LUser, LServer) ->
end. end.
try_auto_webpresence(LUser, LServer) -> try_auto_webpresence(LUser, LServer) ->
From = jlib:make_jid(LUser, LServer, <<"">>), From = jid:make(LUser, LServer, <<"">>),
case acl:match_rule(LServer, ?AUTO_ACL, From) of case acl:match_rule(LServer, ?AUTO_ACL, From) of
deny -> deny ->
#webpresence{}; #webpresence{};
@ -557,7 +554,7 @@ try_auto_webpresence(LUser, LServer) ->
ridurl = false, ridurl = false,
jidurl = true, jidurl = true,
xml = true, xml = true,
avatar = false, avatar = true,
js = true, js = true,
text = true, text = true,
icon = "jsf-jabber-text"} icon = "jsf-jabber-text"}
@ -805,14 +802,14 @@ show_presence({text, WP, LUser, LServer, LResource}) ->
show_presence({avatar, WP, LUser, LServer}) -> show_presence({avatar, WP, LUser, LServer}) ->
true = WP#webpresence.avatar, true = WP#webpresence.avatar,
[{_, Module, Function, _Opts}] = ets:lookup(sm_iqtable, {?NS_VCARD, LServer}), [{_, Module, Function}] = ets:lookup(ejabberd_sm, {LServer, ?NS_VCARD}),
JID = jlib:make_jid(LUser, LServer, <<"">>), JID = jid:make(LUser, LServer, <<"">>),
IQ = #iq{type = get}, %%+++++, xmlns = ?NS_VCARD}, IQ = #iq{type = get, from = JID, to = JID},
IQr = Module:Function(JID, JID, IQ), IQr = Module:Function(IQ),
[VCard] = ok, %%+++++ IQr#iq.sub_el, [VCard] = IQr#iq.sub_els,
Mime = fxml:get_path_s(VCard, [{elem, <<"PHOTO">>}, {elem, <<"TYPE">>}, cdata]), Mime = fxml:get_path_s(VCard, [{elem, <<"PHOTO">>}, {elem, <<"TYPE">>}, cdata]),
BinVal = fxml:get_path_s(VCard, [{elem, <<"PHOTO">>}, {elem, <<"BINVAL">>}, cdata]), BinVal = fxml:get_path_s(VCard, [{elem, <<"PHOTO">>}, {elem, <<"BINVAL">>}, cdata]),
Photo = jlib:decode_base64(BinVal), Photo = misc:decode_base64(BinVal),
{200, [{"Content-Type", Mime}], Photo}; {200, [{"Content-Type", Mime}], Photo};
show_presence({image_example, Theme, Show}) -> show_presence({image_example, Theme, Show}) ->
@ -918,9 +915,9 @@ process2([User, Server | Tail], Request) ->
serve_web_presence(jid, User, Server, Tail, Request). serve_web_presence(jid, User, Server, Tail, Request).
serve_web_presence(TypeURL, User, Server, Tail, #request{lang = Lang1, q = Q}) -> serve_web_presence(TypeURL, User, Server, Tail, #request{lang = Lang1, q = Q}) ->
LServer = jlib:nameprep(Server), LServer = jid:nameprep(Server),
true = lists:member(Server, ejabberd_config:get_myhosts()), true = lists:member(Server, ejabberd_config:get_myhosts()),
LUser = jlib:nodeprep(User), LUser = jid:nodeprep(User),
WP = get_wp(LUser, LServer), WP = get_wp(LUser, LServer),
case TypeURL of case TypeURL of
jid -> true = WP#webpresence.jidurl; jid -> true = WP#webpresence.jidurl;