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:
commit
f749c91e36
|
@ -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) ->
|
||||||
|
|
Loading…
Reference in New Issue