26
1
mirror of https://github.com/processone/ejabberd.git synced 2025-01-03 18:02:28 +01:00

Add better error reporting to mod_muc_admin commands

This commit is contained in:
Paweł Chmielowski 2020-10-20 17:57:19 +02:00
parent b64fff1faa
commit 7655e10ba4

View File

@ -405,12 +405,25 @@ build_summary_room(Name, Host, Pid) ->
}. }.
muc_register_nick(Nick, FromBinary, Service) -> muc_register_nick(Nick, FromBinary, Service) ->
ServerHost = get_room_serverhost(Service), try {get_room_serverhost(Service), jid:decode(FromBinary)} of
From = jid:decode(FromBinary), {ServerHost, From} ->
Lang = <<"en">>, Lang = <<"en">>,
case mod_muc:iq_set_register_info(ServerHost, Service, From, Nick, Lang) of case mod_muc:iq_set_register_info(ServerHost, Service, From, Nick, Lang) of
{result, undefined} -> ok; {result, undefined} -> ok;
E -> E {error, #stanza_error{reason = 'conflict'}} ->
throw({error, "Nick already registered"});
{error, _} ->
throw({error, "Database error"})
end
catch
error:{invalid_domain, _} ->
throw({error, "Invalid 'service'"});
error:{unregistered_route, _} ->
throw({error, "Invalid 'service'"});
error:{bad_jid, _} ->
throw({error, "Invalid 'jid'"});
_ ->
throw({error, "Internal error"})
end. end.
muc_unregister_nick(FromBinary, Service) -> muc_unregister_nick(FromBinary, Service) ->
@ -632,10 +645,14 @@ create_room(Name1, Host1, ServerHost) ->
create_room_with_opts(Name1, Host1, ServerHost, []). create_room_with_opts(Name1, Host1, ServerHost, []).
create_room_with_opts(Name1, Host1, ServerHost1, CustomRoomOpts) -> create_room_with_opts(Name1, Host1, ServerHost1, CustomRoomOpts) ->
true = (error /= (Name = jid:nodeprep(Name1))), case {jid:nodeprep(Name1), jid:nodeprep(Host1), jid:nodeprep(ServerHost1)} of
true = (error /= (Host = jid:nodeprep(Host1))), {error, _, _} ->
true = (error /= (ServerHost = jid:nodeprep(ServerHost1))), throw({error, "Invalid 'name'"});
{_, error, _} ->
throw({error, "Invalid 'host'"});
{_, _, error} ->
throw({error, "Invalid 'serverhost'"});
{Name, Host, ServerHost} ->
%% Get the default room options from the muc configuration %% Get the default room options from the muc configuration
DefRoomOpts = mod_muc_opt:default_room_options(ServerHost), DefRoomOpts = mod_muc_opt:default_room_options(ServerHost),
%% Change default room options as required %% Change default room options as required
@ -678,7 +695,8 @@ create_room_with_opts(Name1, Host1, ServerHost1, CustomRoomOpts) ->
mod_muc:register_online_room(Name, Host, Pid), mod_muc:register_online_room(Name, Host, Pid),
ok; ok;
_ -> _ ->
error throw({error, "Room already exists"})
end
end. end.
%% Create the room only in the database. %% Create the room only in the database.
@ -695,9 +713,12 @@ muc_create_room(ServerHost, {Name, Host, _}, DefRoomOpts) ->
destroy_room(Name, Service) -> destroy_room(Name, Service) ->
case get_room_pid(Name, Service) of case get_room_pid(Name, Service) of
room_not_found -> room_not_found ->
error; throw({error, "Room doesn't exists"});
invalid_service ->
throw({error, "Invalid 'service'"});
Pid -> Pid ->
mod_muc_room:destroy(Pid) mod_muc_room:destroy(Pid),
ok
end. end.
destroy_room({N, H, SH}) -> destroy_room({N, H, SH}) ->
@ -908,8 +929,8 @@ act_on_room(_Method, list, _) ->
get_room_occupants(Room, Host) -> get_room_occupants(Room, Host) ->
case get_room_pid(Room, Host) of case get_room_pid(Room, Host) of
room_not_found -> throw({error, room_not_found}); Pid when is_pid(Pid) -> get_room_occupants(Pid);
Pid -> get_room_occupants(Pid) _ -> throw({error, room_not_found})
end. end.
get_room_occupants(Pid) -> get_room_occupants(Pid) ->
@ -924,11 +945,11 @@ get_room_occupants(Pid) ->
get_room_occupants_number(Room, Host) -> get_room_occupants_number(Room, Host) ->
case get_room_pid(Room, Host) of case get_room_pid(Room, Host) of
room_not_found -> Pid when is_pid(Pid )->
throw({error, room_not_found});
Pid ->
S = get_room_state(Pid), S = get_room_state(Pid),
maps:size(S#state.users) maps:size(S#state.users);
_ ->
throw({error, room_not_found})
end. end.
%%---------------------------- %%----------------------------
@ -937,12 +958,16 @@ get_room_occupants_number(Room, Host) ->
%% http://xmpp.org/extensions/xep-0249.html %% http://xmpp.org/extensions/xep-0249.html
send_direct_invitation(RoomName, RoomService, Password, Reason, UsersString) -> send_direct_invitation(RoomName, RoomService, Password, Reason, UsersString) ->
RoomJid = jid:make(RoomName, RoomService), case jid:make(RoomName, RoomService) of
error ->
throw({error, "Invalid 'roomname' or 'service'"});
RoomJid ->
XmlEl = build_invitation(Password, Reason, RoomJid), XmlEl = build_invitation(Password, Reason, RoomJid),
Users = get_users_to_invite(RoomJid, UsersString), Users = get_users_to_invite(RoomJid, UsersString),
[send_direct_invitation(RoomJid, UserJid, XmlEl) [send_direct_invitation(RoomJid, UserJid, XmlEl)
|| UserJid <- Users], || UserJid <- Users],
ok. ok
end.
get_users_to_invite(RoomJid, UsersString) -> get_users_to_invite(RoomJid, UsersString) ->
UsersStrings = binary:split(UsersString, <<":">>, [global]), UsersStrings = binary:split(UsersString, <<":">>, [global]),
@ -996,7 +1021,9 @@ send_direct_invitation(FromJid, UserJid, Msg) ->
change_room_option(Name, Service, OptionString, ValueString) -> change_room_option(Name, Service, OptionString, ValueString) ->
case get_room_pid(Name, Service) of case get_room_pid(Name, Service) of
room_not_found -> room_not_found ->
room_not_found; throw({error, "Room not found"});
invalid_service ->
throw({error, "Invalid 'service'"});
Pid -> Pid ->
{Option, Value} = format_room_option(OptionString, ValueString), {Option, Value} = format_room_option(OptionString, ValueString),
change_room_option(Pid, Option, Value) change_room_option(Pid, Option, Value)
@ -1036,13 +1063,21 @@ format_room_option(OptionString, ValueString) ->
{Option, Value}. {Option, Value}.
%% @doc Get the Pid of an existing MUC room, or 'room_not_found'. %% @doc Get the Pid of an existing MUC room, or 'room_not_found'.
-spec get_room_pid(binary(), binary()) -> {ok, pid()} | room_not_found | invalid_service.
get_room_pid(Name, Service) -> get_room_pid(Name, Service) ->
ServerHost = get_room_serverhost(Service), try get_room_serverhost(Service) of
ServerHost ->
case mod_muc:unhibernate_room(ServerHost, Service, Name) of case mod_muc:unhibernate_room(ServerHost, Service, Name) of
error -> error ->
room_not_found; room_not_found;
{ok, Pid} -> {ok, Pid} ->
Pid Pid
end
catch
error:{invalid_domain, _} ->
invalid_service;
error:{unregistered_route, _} ->
invalid_service
end. end.
%% It is required to put explicitly all the options because %% It is required to put explicitly all the options because
@ -1085,8 +1120,8 @@ change_option(Option, Value, Config) ->
get_room_options(Name, Service) -> get_room_options(Name, Service) ->
case get_room_pid(Name, Service) of case get_room_pid(Name, Service) of
room_not_found -> []; Pid when is_pid(Pid) -> get_room_options(Pid);
Pid -> get_room_options(Pid) _ -> []
end. end.
get_room_options(Pid) -> get_room_options(Pid) ->
@ -1121,7 +1156,7 @@ get_room_affiliations(Name, Service) ->
({{Uname, Domain, _Res}, Aff}) when is_atom(Aff)-> ({{Uname, Domain, _Res}, Aff}) when is_atom(Aff)->
{Uname, Domain, Aff, <<>>} {Uname, Domain, Aff, <<>>}
end, Affiliations); end, Affiliations);
room_not_found -> _ ->
throw({error, "The room does not exist."}) throw({error, "The room does not exist."})
end. end.
@ -1140,7 +1175,7 @@ get_room_affiliation(Name, Service, JID) ->
{ok, StateData} = mod_muc_room:get_state(Pid), {ok, StateData} = mod_muc_room:get_state(Pid),
UserJID = jid:decode(JID), UserJID = jid:decode(JID),
mod_muc_room:get_affiliation(UserJID, StateData); mod_muc_room:get_affiliation(UserJID, StateData);
room_not_found -> _ ->
throw({error, "The room does not exist."}) throw({error, "The room does not exist."})
end. end.
@ -1165,7 +1200,9 @@ set_room_affiliation(Name, Service, JID, AffiliationString) ->
mod_muc:store_room(StateData#state.server_host, StateData#state.host, StateData#state.room, make_opts(StateData)), mod_muc:store_room(StateData#state.server_host, StateData#state.host, StateData#state.room, make_opts(StateData)),
ok; ok;
room_not_found -> room_not_found ->
error throw({error, "Room doesn't exists"});
invalid_service ->
throw({error, "Invalid 'service'"})
end. end.
%%% %%%