Merge pull request #77 from mojolingo/feature/mod_muc_admin/affiliation_change_stanzas

Rely on core routine for handling affiliation changes
This commit is contained in:
badlop 2015-02-26 11:48:27 +01:00
commit f749c91e36
1 changed files with 2 additions and 12 deletions

View File

@ -822,23 +822,13 @@ set_room_affiliation(Name, Service, JID, AffiliationString) ->
[R] -> [R] ->
%% Get the PID for the online room so we can get the state of the room %% Get the PID for the online room so we can get the state of the room
Pid = R#muc_online_room.pid, Pid = R#muc_online_room.pid,
{ok, StateData} = gen_fsm:sync_send_all_state_event(Pid, get_state), {ok, StateData} = gen_fsm:sync_send_all_state_event(Pid, {process_item_change, {jlib:string_to_jid(JID), affiliation, Affiliation, <<"">>}, <<"">>}),
SJID = jlib:string_to_jid(JID), mod_muc:store_room(StateData#state.server_host, StateData#state.host, StateData#state.room, make_opts(StateData)),
LJID = jlib:jid_remove_resource(jlib:jid_tolower(SJID)),
Affiliations = change_affiliation(Affiliation, LJID, StateData#state.affiliations),
Res = StateData#state{affiliations = Affiliations},
{ok, _State} = gen_fsm:sync_send_all_state_event(Pid, {change_state, Res}),
mod_muc:store_room(Res#state.server_host, Res#state.host, Res#state.room, make_opts(Res)),
ok; ok;
[] -> [] ->
error error
end. end.
change_affiliation(none, LJID, Affiliations) ->
?DICT:erase(LJID, Affiliations);
change_affiliation(Affiliation, LJID, Affiliations) ->
?DICT:store(LJID, Affiliation, Affiliations).
-define(MAKE_CONFIG_OPT(Opt), {Opt, Config#config.Opt}). -define(MAKE_CONFIG_OPT(Opt), {Opt, Config#config.Opt}).
make_opts(StateData) -> make_opts(StateData) ->