24
1
mirror of https://github.com/processone/ejabberd.git synced 2024-06-12 21:52:07 +02:00

* src/ejabberd_s2s.erl: Added error catching for do_route/3

* src/ejabberd_local.erl: Likewise for do_route/4

* src/msgs/ru.msg: Updated

* src/mod_muc/mod_muc_room.erl: New option to allow to view list
of participants for non-ones via disco#items

* src/mod_muc/mod_muc_room.erl: Store room subject with
configuration options

SVN Revision: 109
This commit is contained in:
Alexey Shchepin 2003-05-15 18:16:13 +00:00
parent 2d3aa901a9
commit ee15945cd7
6 changed files with 70 additions and 18 deletions

View File

@ -1,3 +1,16 @@
2003-05-15 Alexey Shchepin <alexey@sevcom.net>
* src/ejabberd_s2s.erl: Added error catching for do_route/3
* src/ejabberd_local.erl: Likewise for do_route/4
* src/msgs/ru.msg: Updated
* src/mod_muc/mod_muc_room.erl: New option to allow to view list
of participants for non-ones via disco#items
* src/mod_muc/mod_muc_room.erl: Store room subject with
configuration options
2003-05-14 Alexey Shchepin <alexey@sevcom.net> 2003-05-14 Alexey Shchepin <alexey@sevcom.net>
* src/mod_muc/mod_muc_room.erl: Remove user from room on receiving * src/mod_muc/mod_muc_room.erl: Remove user from room on receiving

16
TODO
View File

@ -6,15 +6,21 @@ admin interface
node restart/shutdown node restart/shutdown
statistics about memory usage statistics about memory usage
backup management backup management
S2S timeouts
rewrite S2S key validation S2S:
iq:browse (?) * timeouts
* rewrite S2S key validation
more correctly work with SRV DNS records (priority, weight, etc...) more correctly work with SRV DNS records (priority, weight, etc...)
SSL SSL
SASL
JEP-62,63 (?) JEP-62,63 (?)
make roster set to work in one transaction make roster set to work in one transaction
add traffic shapers to to c2s connection before authentification add traffic shapers to c2s connection before authentification
add traffic shapers to s2s connections add traffic shapers to s2s connections
more traffic shapers more traffic shapers
SNMP SNMP
mod_muc:
* broadcast messages from admin

View File

@ -37,7 +37,12 @@ init() ->
loop(State) -> loop(State) ->
receive receive
{route, From, To, Packet} -> {route, From, To, Packet} ->
do_route(State, From, To, Packet), case catch do_route(State, From, To, Packet) of
{'EXIT', Reason} ->
?ERROR_MSG("~p", [Reason]);
_ ->
ok
end,
loop(State); loop(State);
{register_iq_handler, XMLNS, Module, Function} -> {register_iq_handler, XMLNS, Module, Function} ->
ets:insert(State#state.iqtable, {XMLNS, Module, Function}), ets:insert(State#state.iqtable, {XMLNS, Module, Function}),

View File

@ -55,7 +55,12 @@ loop() ->
clean_table_from_bad_node(Node), clean_table_from_bad_node(Node),
loop(); loop();
{route, From, To, Packet} -> {route, From, To, Packet} ->
do_route(From, To, Packet), case catch do_route(From, To, Packet) of
{'EXIT', Reason} ->
?ERROR_MSG("~p", [Reason]);
_ ->
ok
end,
loop(); loop();
_ -> _ ->
loop() loop()

View File

@ -40,6 +40,7 @@
allow_query_users = true, allow_query_users = true,
allow_private_messages = true, allow_private_messages = true,
public = true, public = true,
public_list = true,
persistent = false, persistent = false,
moderated = false, % TODO moderated = false, % TODO
members_by_default = true, members_by_default = true,
@ -146,10 +147,20 @@ normal_state({route, From, "",
case can_change_subject(Role, case can_change_subject(Role,
StateData) of StateData) of
true -> true ->
{StateData#state{ NSD =
StateData#state{
subject = Subject, subject = Subject,
subject_author = FromNick}, subject_author =
true}; FromNick},
case (NSD#state.config)#config.persistent of
true ->
mod_muc:store_room(
NSD#state.room,
make_opts(NSD));
_ ->
ok
end,
{NSD, true};
_ -> _ ->
{StateData, false} {StateData, false}
end end
@ -1496,9 +1507,6 @@ process_iq_owner(From, set, SubEl, StateData) ->
_ -> _ ->
{error, ?ERR_FORBIDDEN} {error, ?ERR_FORBIDDEN}
end; end;
% {xmlelement, _, _, Items} = SubEl,
% process_admin_items_set(From, Items, StateData);
% {error, ?ERR_FEATURE_NOT_IMPLEMENTED};
process_iq_owner(From, get, SubEl, StateData) -> process_iq_owner(From, get, SubEl, StateData) ->
FAffiliation = get_affiliation(From, StateData), FAffiliation = get_affiliation(From, StateData),
@ -1567,6 +1575,9 @@ get_config(Lang, StateData) ->
?BOOLXFIELD("Make room public searchable?", ?BOOLXFIELD("Make room public searchable?",
"public", "public",
Config#config.public), Config#config.public),
?BOOLXFIELD("Make participants list public?",
"public_list",
Config#config.public_list),
?BOOLXFIELD("Make room persistent?", ?BOOLXFIELD("Make room persistent?",
"persistent", "persistent",
Config#config.persistent), Config#config.persistent),
@ -1634,6 +1645,8 @@ set_xoption([{"allow_private_messages", [Val]} | Opts], Config) ->
?SET_BOOL_XOPT(allow_private_messages, Val); ?SET_BOOL_XOPT(allow_private_messages, Val);
set_xoption([{"public", [Val]} | Opts], Config) -> set_xoption([{"public", [Val]} | Opts], Config) ->
?SET_BOOL_XOPT(public, Val); ?SET_BOOL_XOPT(public, Val);
set_xoption([{"public_list", [Val]} | Opts], Config) ->
?SET_BOOL_XOPT(public_list, Val);
set_xoption([{"persistent", [Val]} | Opts], Config) -> set_xoption([{"persistent", [Val]} | Opts], Config) ->
?SET_BOOL_XOPT(persistent, Val); ?SET_BOOL_XOPT(persistent, Val);
set_xoption([{"moderated", [Val]} | Opts], Config) -> set_xoption([{"moderated", [Val]} | Opts], Config) ->
@ -1681,6 +1694,7 @@ set_opts([{Opt, Val} | Opts], StateData) ->
?CASE_CONFIG_OPT(allow_query_users); ?CASE_CONFIG_OPT(allow_query_users);
?CASE_CONFIG_OPT(allow_private_messages); ?CASE_CONFIG_OPT(allow_private_messages);
?CASE_CONFIG_OPT(public); ?CASE_CONFIG_OPT(public);
?CASE_CONFIG_OPT(public_list);
?CASE_CONFIG_OPT(persistent); ?CASE_CONFIG_OPT(persistent);
?CASE_CONFIG_OPT(moderated); ?CASE_CONFIG_OPT(moderated);
?CASE_CONFIG_OPT(members_by_default); ?CASE_CONFIG_OPT(members_by_default);
@ -1691,6 +1705,10 @@ set_opts([{Opt, Val} | Opts], StateData) ->
?CASE_CONFIG_OPT(logging); ?CASE_CONFIG_OPT(logging);
affiliations -> affiliations ->
StateData#state{affiliations = ?DICT:from_list(Val)}; StateData#state{affiliations = ?DICT:from_list(Val)};
subject ->
StateData#state{subject = Val};
subject_author ->
StateData#state{subject_author = Val};
_ -> StateData _ -> StateData
end, end,
set_opts(Opts, NSD). set_opts(Opts, NSD).
@ -1705,6 +1723,7 @@ make_opts(StateData) ->
?MAKE_CONFIG_OPT(allow_query_users), ?MAKE_CONFIG_OPT(allow_query_users),
?MAKE_CONFIG_OPT(allow_private_messages), ?MAKE_CONFIG_OPT(allow_private_messages),
?MAKE_CONFIG_OPT(public), ?MAKE_CONFIG_OPT(public),
?MAKE_CONFIG_OPT(public_list),
?MAKE_CONFIG_OPT(persistent), ?MAKE_CONFIG_OPT(persistent),
?MAKE_CONFIG_OPT(moderated), ?MAKE_CONFIG_OPT(moderated),
?MAKE_CONFIG_OPT(members_by_default), ?MAKE_CONFIG_OPT(members_by_default),
@ -1713,7 +1732,9 @@ make_opts(StateData) ->
?MAKE_CONFIG_OPT(password_protected), ?MAKE_CONFIG_OPT(password_protected),
?MAKE_CONFIG_OPT(anonymous), ?MAKE_CONFIG_OPT(anonymous),
?MAKE_CONFIG_OPT(logging), ?MAKE_CONFIG_OPT(logging),
{affiliations, ?DICT:to_list(StateData#state.affiliations)} {affiliations, ?DICT:to_list(StateData#state.affiliations)},
{subject, StateData#state.subject},
{subject_author, StateData#state.subject_author}
]. ].
@ -1760,8 +1781,9 @@ process_iq_disco_items(From, set, StateData) ->
process_iq_disco_items(From, get, StateData) -> process_iq_disco_items(From, get, StateData) ->
FAffiliation = get_affiliation(From, StateData), FAffiliation = get_affiliation(From, StateData),
FRole = get_role(From, StateData), FRole = get_role(From, StateData),
case (FRole /= none) or case ((StateData#state.config)#config.public_list == true) orelse
(FAffiliation == admin) or (FRole /= none) orelse
(FAffiliation == admin) orelse
(FAffiliation == owner) of (FAffiliation == owner) of
true -> true ->
UList = UList =

View File

@ -72,6 +72,7 @@
{"Allow users to send private messages?", {"Allow users to send private messages?",
"Разрешить приватные сообщения?"}. "Разрешить приватные сообщения?"}.
{"Make room public searchable?", "Сделать комнату видимой всем?"}. {"Make room public searchable?", "Сделать комнату видимой всем?"}.
{"Make participants list public?", "Сделать список участников видимым всем?"}.
{"Make room persistent?", "Сделать комнату постоянной?"}. {"Make room persistent?", "Сделать комнату постоянной?"}.
{"Make room moderated?", "Сделать комнату модерируемой?"}. {"Make room moderated?", "Сделать комнату модерируемой?"}.
{"Default users as members?", {"Default users as members?",