lists:foldl(
fun(E, SD) ->
process_admin_items_set(E, SD)
- 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,
_ ->
case exmpp_xml:get_attribute(Item, <<"nick">>, false) of
N when N =/= false ->
- case find_jid_by_nick(N, StateData) of
+ case find_jids_by_nick(N, StateData) of
false ->
ErrText =
io_lib:format(
end
end,
case TJID of
- {value, JID} ->
+ {value, [JID|_]=JIDs} ->
TAffiliation = get_affiliation(JID, StateData),
TRole = get_role(JID, StateData),
case exmpp_xml:get_attribute_as_binary(Item, <<"role">>,false) of
Items, Lang, StateData,
Res);
true ->
+ Reason = exmpp_xml:get_path(Item, [{element, 'reason'}, cdata]),
+ MoreRes = [{exmpp_jid:bare(Jidx), affiliation, SAffiliation, Reason} || Jidx <- JIDs],
find_changed_items(
UJID,
UAffiliation, URole,
Items, Lang, StateData,
- [{exmpp_jid:bare(JID),
- affiliation,
- SAffiliation,
- exmpp_xml:get_path(
- Item, [{element, 'reason'},
- cdata])} | Res]);
+ [MoreRes | Res]);
false ->
{error, 'not-allowed'}
end
Items, Lang, StateData,
Res);
true ->
+ Reason = exmpp_xml:get_path(Item, [{element, 'reason'}, cdata]),
+ MoreRes = [{Jidx, role, SRole, Reason} || Jidx <- JIDs],
find_changed_items(
UJID,
UAffiliation, URole,
Items, Lang, StateData,
- [{JID, role, SRole,
- exmpp_xml:get_path(
- Item, [{element, 'reason'},
- cdata])} | Res]);
+ [MoreRes | Res]);
_ ->
{error, 'not-allowed'}
end