aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBadlop <badlop@process-one.net>2011-09-08 16:10:38 +0200
committerBadlop <badlop@process-one.net>2011-09-08 16:10:38 +0200
commitb8969f68e08e0a5685fd2aee1d1313095e20a31e (patch)
treedb86ca293fe3433c13657218aa7836416fc550b1
parentFix room config change logging, due to allow_private_messages_from_visitors (diff)
Fixed support for multi-resource occupants (EJAB-305)
-rw-r--r--src/mod_muc/mod_muc_room.erl22
1 files changed, 9 insertions, 13 deletions
diff --git a/src/mod_muc/mod_muc_room.erl b/src/mod_muc/mod_muc_room.erl
index abb53e032..6483bfb45 100644
--- a/src/mod_muc/mod_muc_room.erl
+++ b/src/mod_muc/mod_muc_room.erl
@@ -2464,7 +2464,7 @@ process_admin_items_set(UJID, Items, Lang, StateData) ->
NSD ->
NSD
end
- end, StateData, Res),
+ end, StateData, lists:flatten(Res)),
case (NSD#state.config)#config.persistent of
true ->
mod_muc:store_room(NSD#state.host, NSD#state.room,
@@ -2501,7 +2501,7 @@ find_changed_items(UJID, UAffiliation, URole,
_ ->
case xml:get_attr("nick", Attrs) of
{value, N} ->
- case find_jid_by_nick(N, StateData) of
+ case find_jids_by_nick(N, StateData) of
false ->
ErrText =
io_lib:format(
@@ -2518,7 +2518,7 @@ find_changed_items(UJID, UAffiliation, URole,
end
end,
case TJID of
- {value, JID} ->
+ {value, [JID|_]=JIDs} ->
TAffiliation = get_affiliation(JID, StateData),
TRole = get_role(JID, StateData),
case xml:get_attr("role", Attrs) of
@@ -2568,16 +2568,13 @@ find_changed_items(UJID, UAffiliation, URole,
Items, Lang, StateData,
Res);
true ->
+ Reason = xml:get_path_s(Item, [{elem, "reason"}, cdata]),
+ MoreRes = [{jlib:jid_remove_resource(Jidx), affiliation, SAffiliation, Reason} || Jidx <- JIDs],
find_changed_items(
UJID,
UAffiliation, URole,
Items, Lang, StateData,
- [{jlib:jid_remove_resource(JID),
- affiliation,
- SAffiliation,
- xml:get_path_s(
- Item, [{elem, "reason"},
- cdata])} | Res]);
+ [MoreRes | Res]);
false ->
{error, ?ERR_NOT_ALLOWED}
end
@@ -2625,14 +2622,13 @@ find_changed_items(UJID, UAffiliation, URole,
Items, Lang, StateData,
Res);
true ->
+ Reason = xml:get_path_s(Item, [{elem, "reason"}, cdata]),
+ MoreRes = [{Jidx, role, SRole, Reason} || Jidx <- JIDs],
find_changed_items(
UJID,
UAffiliation, URole,
Items, Lang, StateData,
- [{JID, role, SRole,
- xml:get_path_s(
- Item, [{elem, "reason"},
- cdata])} | Res]);
+ [MoreRes | Res]);
_ ->
{error, ?ERR_NOT_ALLOWED}
end