25
1
mirror of https://github.com/processone/ejabberd.git synced 2024-11-22 16:20:52 +01:00

mod_muc_room: Notify on affiliation changes

Notify the current room occupants if the affiliation of a non-occupant
is changed as per example 195 of XEP-0045.  In anonymous rooms, only
moderators are notified, though.
This commit is contained in:
Holger Weiss 2016-05-20 01:28:16 +02:00
parent ba2680df61
commit 9d87a4a6d4
2 changed files with 58 additions and 0 deletions

View File

@ -266,6 +266,8 @@ normal_state({route, From, <<"">>,
none -> none ->
NSD = set_affiliation(IJID, member, NSD = set_affiliation(IJID, member,
StateData), StateData),
send_affiliation(IJID, member,
StateData),
case case
(NSD#state.config)#config.persistent (NSD#state.config)#config.persistent
of of
@ -2440,6 +2442,51 @@ send_nick_changing(JID, OldNick, StateData,
end, end,
(?DICT):to_list(StateData#state.users)). (?DICT):to_list(StateData#state.users)).
maybe_send_affiliation(JID, Affiliation, StateData) ->
LJID = jid:tolower(JID),
IsOccupant = case LJID of
{LUser, LServer, <<"">>} ->
not (?DICT):is_empty(
(?DICT):filter(fun({U, S, _}, _) ->
U == LUser andalso
S == LServer
end, StateData#state.users));
{_LUser, _LServer, _LResource} ->
(?DICT):is_key(LJID, StateData#state.users)
end,
case IsOccupant of
true ->
ok; % The new affiliation is published via presence.
false ->
send_affiliation(LJID, Affiliation, StateData)
end.
send_affiliation(LJID, Affiliation, StateData) ->
ItemAttrs = [{<<"jid">>, jid:to_string(LJID)},
{<<"affiliation">>, affiliation_to_list(Affiliation)},
{<<"role">>, <<"none">>}],
Message = #xmlel{name = <<"message">>,
attrs = [{<<"id">>, randoms:get_string()}],
children =
[#xmlel{name = <<"x">>,
attrs = [{<<"xmlns">>, ?NS_MUC_USER}],
children =
[#xmlel{name = <<"item">>,
attrs = ItemAttrs}]}]},
Recipients = case (StateData#state.config)#config.anonymous of
true ->
(?DICT):filter(fun(_, #user{role = moderator}) ->
true;
(_, _) ->
false
end, StateData#state.users);
false ->
StateData#state.users
end,
send_multiple(StateData#state.jid,
StateData#state.server_host,
Recipients, Message).
status_els(IsInitialPresence, JID, #user{jid = JID}, StateData) -> status_els(IsInitialPresence, JID, #user{jid = JID}, StateData) ->
Status = case IsInitialPresence of Status = case IsInitialPresence of
true -> true ->
@ -2722,11 +2769,13 @@ process_item_change(E, SD, UJID) ->
<<"321">>, <<"321">>,
none, none,
SD), SD),
maybe_send_affiliation(JID, none, SD),
SD1 = set_affiliation(JID, none, SD), SD1 = set_affiliation(JID, none, SD),
set_role(JID, none, SD1); set_role(JID, none, SD1);
_ -> _ ->
SD1 = set_affiliation(JID, none, SD), SD1 = set_affiliation(JID, none, SD),
send_update_presence(JID, SD1, SD), send_update_presence(JID, SD1, SD),
maybe_send_affiliation(JID, none, SD1),
SD1 SD1
end; end;
{JID, affiliation, outcast, Reason} -> {JID, affiliation, outcast, Reason} ->
@ -2736,6 +2785,7 @@ process_item_change(E, SD, UJID) ->
<<"301">>, <<"301">>,
outcast, outcast,
SD), SD),
maybe_send_affiliation(JID, outcast, SD),
set_affiliation(JID, set_affiliation(JID,
outcast, outcast,
set_role(JID, none, SD), set_role(JID, none, SD),
@ -2745,11 +2795,13 @@ process_item_change(E, SD, UJID) ->
SD1 = set_affiliation(JID, A, SD, Reason), SD1 = set_affiliation(JID, A, SD, Reason),
SD2 = set_role(JID, moderator, SD1), SD2 = set_role(JID, moderator, SD1),
send_update_presence(JID, Reason, SD2, SD), send_update_presence(JID, Reason, SD2, SD),
maybe_send_affiliation(JID, A, SD2),
SD2; SD2;
{JID, affiliation, member, Reason} -> {JID, affiliation, member, Reason} ->
SD1 = set_affiliation(JID, member, SD, Reason), SD1 = set_affiliation(JID, member, SD, Reason),
SD2 = set_role(JID, participant, SD1), SD2 = set_role(JID, participant, SD1),
send_update_presence(JID, Reason, SD2, SD), send_update_presence(JID, Reason, SD2, SD),
maybe_send_affiliation(JID, member, SD2),
SD2; SD2;
{JID, role, Role, Reason} -> {JID, role, Role, Reason} ->
SD1 = set_role(JID, Role, SD), SD1 = set_role(JID, Role, SD),
@ -2759,6 +2811,7 @@ process_item_change(E, SD, UJID) ->
{JID, affiliation, A, _Reason} -> {JID, affiliation, A, _Reason} ->
SD1 = set_affiliation(JID, A, SD), SD1 = set_affiliation(JID, A, SD),
send_update_presence(JID, SD1, SD), send_update_presence(JID, SD1, SD),
maybe_send_affiliation(JID, A, SD1),
SD1 SD1
end end
of of

View File

@ -1435,6 +1435,11 @@ muc_master(Config) ->
items = [#muc_item{affiliation = member, items = [#muc_item{affiliation = member,
jid = PeerJID, jid = PeerJID,
role = participant}]}]}), role = participant}]}]}),
?recv1(#message{from = Room,
sub_els = [#muc_user{
items = [#muc_item{affiliation = member,
jid = Localhost,
role = none}]}]}),
%% BUG: We should not receive any sub_els! %% BUG: We should not receive any sub_els!
?recv1(#iq{type = result, id = I1, sub_els = [_|_]}), ?recv1(#iq{type = result, id = I1, sub_els = [_|_]}),
%% Receive groupchat message from the peer %% Receive groupchat message from the peer