26
1
mirror of https://github.com/processone/ejabberd.git synced 2025-01-01 17:53:00 +01:00

*** empty log message ***

SVN Revision: 44
This commit is contained in:
Alexey Shchepin 2003-01-19 20:17:56 +00:00
parent 942fbb9fae
commit bacbeeaaa4
8 changed files with 279 additions and 38 deletions

1
TODO
View File

@ -1,3 +1,4 @@
admin interface
S2S timeouts S2S timeouts
iq:browse(?) iq:browse(?)
SVR DNS records SVR DNS records

View File

@ -22,8 +22,12 @@ add(ACLName, ACLData) ->
ets:insert(acls, {ACLName, ACLData}). ets:insert(acls, {ACLName, ACLData}).
match_rule(Rule, JID) -> match_rule(Rule, JID) ->
ACLs = ejabberd_config:get_option(Rule), case ejabberd_config:get_option(Rule) of
match_acls(ACLs, JID). undefined ->
deny;
ACLs ->
match_acls(ACLs, JID)
end.
match_acls([], _) -> match_acls([], _) ->
deny; deny;

View File

@ -2,12 +2,18 @@
{acl, admin, {user, "aleksey"}}. {acl, admin, {user, "aleksey"}}.
{acl, admin, {user, "ermine"}}. {acl, admin, {user, "ermine"}}.
{acl, admin, {user, "test"}}.
{acl, admin, {user, "aleksey", "jabber.ru"}}.
{acl, admin, {user, "ermine", "jabber.ru"}}.
{acl, jabberorg, {server, "jabber.org"}}. {acl, jabberorg, {server, "jabber.org"}}.
{acl, aleksey, {user, "aleksey", "jabber.ru"}}. {acl, aleksey, {user, "aleksey", "jabber.ru"}}.
{disco_admin, [{allow, admin}, {disco_admin, [{allow, admin},
{deny, all}]}. {deny, all}]}.
{configure, [{allow, admin}]}.
{host, "e.localhost"}. {host, "e.localhost"}.
{listen, [{5522, ejabberd_c2s, start, []}, {listen, [{5522, ejabberd_c2s, start, []},

View File

@ -22,6 +22,7 @@ start() ->
register(ejabberd_local, spawn(ejabberd_local, init, [])), register(ejabberd_local, spawn(ejabberd_local, init, [])),
mod_register:start(), mod_register:start(),
mod_roster:start(), mod_roster:start(),
mod_configure:start(),
mod_disco:start(), mod_disco:start(),
mod_stats:start(), mod_stats:start(),
mod_vcard:start(), mod_vcard:start(),

View File

@ -86,24 +86,40 @@ clean_table_from_bad_node(Node) ->
end, end,
mnesia:transaction(F). mnesia:transaction(F).
%have_connection(FromTo) ->
% F = fun() ->
% [E] = mnesia:read({s2s, FromTo})
% end,
% case mnesia:transaction(F) of
% {atomic, _} ->
% true;
% _ ->
% false
% end.
have_connection(FromTo) -> have_connection(FromTo) ->
F = fun() -> case catch mnesia:dirty_read(s2s, FromTo) of
[E] = mnesia:read({s2s, FromTo}) [_] ->
end,
case mnesia:transaction(F) of
{atomic, _} ->
true; true;
_ -> _ ->
false false
end. end.
%get_key(FromTo) ->
% F = fun() ->
% [E] = mnesia:read({s2s, FromTo}),
% E
% end,
% case mnesia:transaction(F) of
% {atomic, E} ->
% E#s2s.key;
% _ ->
% ""
% end.
get_key(FromTo) -> get_key(FromTo) ->
F = fun() -> case catch mnesia:dirty_read(s2s, FromTo) of
[E] = mnesia:read({s2s, FromTo}), [E] ->
E
end,
case mnesia:transaction(F) of
{atomic, E} ->
E#s2s.key; E#s2s.key;
_ -> _ ->
"" ""

View File

@ -297,18 +297,16 @@ route_message(From, To, Packet) ->
get_user_resources(User) -> get_user_resources(User) ->
LUser = jlib:tolower(User), LUser = jlib:tolower(User),
F = fun() -> case catch mnesia:dirty_index_read(session, LUser, #session.user) of
mnemosyne:eval(query [X.ur || X <- table(session), {'EXIT', Reason} ->
X.user = LUser] [];
end) Rs ->
end, lists:map(fun(R) ->
case mnesia:transaction(F) of element(2, R#session.ur)
{atomic, Rs} -> end, Rs)
lists:map(fun(R) -> element(2, R) end, Rs);
{aborted, Reason} ->
[]
end. end.
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
set_presence(User, Resource, Priority) -> set_presence(User, Resource, Priority) ->
@ -330,16 +328,13 @@ unset_presence(User, Resource) ->
get_user_present_resources(User) -> get_user_present_resources(User) ->
LUser = jlib:tolower(User), LUser = jlib:tolower(User),
F = fun() -> case catch mnesia:dirty_index_read(presence, LUser, #presence.user) of
mnesia:index_read(presence, LUser, #presence.user) {'EXIT', Reason} ->
end, [];
case mnesia:transaction(F) of Rs ->
{atomic, Rs} ->
lists:map(fun(R) -> lists:map(fun(R) ->
{R#presence.priority, element(2, R#presence.ur)} {R#presence.priority, element(2, R#presence.ur)}
end, Rs); end, Rs)
{aborted, Reason} ->
[]
end. end.
dirty_get_sessions_list() -> dirty_get_sessions_list() ->

207
src/mod_configure.erl Normal file
View File

@ -0,0 +1,207 @@
%%%----------------------------------------------------------------------
%%% File : mod_configure.erl
%%% Author : Alexey Shchepin <alexey@sevcom.net>
%%% Purpose :
%%% Created : 19 Jan 2003 by Alexey Shchepin <alexey@sevcom.net>
%%% Id : $Id$
%%%----------------------------------------------------------------------
-module(mod_configure).
-author('alexey@sevcom.net').
-vsn('$Revision$ ').
-export([start/0,
process_local_iq/3]).
-include("ejabberd.hrl").
-include("namespaces.hrl").
start() ->
ejabberd_local:register_iq_handler(?NS_XDATA,
?MODULE, process_local_iq).
process_local_iq(From, To, {iq, ID, Type, XMLNS, SubEl}) ->
case acl:match_rule(configure, From) of
deny ->
{iq, ID, error, XMLNS, [SubEl, {xmlelement, "error",
[{"code", "405"}],
[{xmlcdata, "Not Allowed"}]}]};
allow ->
Lang = xml:get_tag_attr_s("xml:lang", SubEl),
case Type of
set ->
case xml:get_tag_attr_s("type", SubEl) of
"cancel" ->
{iq, ID, result, XMLNS,
[{xmlelement, "query", [{"xmlns", XMLNS}], []}]};
"submit" ->
XData = jlib:parse_xdata_submit(SubEl),
case XData of
invalid ->
{iq, ID, error, XMLNS,
[SubEl, {xmlelement, "error",
[{"code", "400"}],
[{xmlcdata, "Bad Request"}]}]};
_ ->
Node =
string:tokens(
xml:get_tag_attr_s("node", SubEl),
"/"),
case set_form(Node, Lang, XData) of
{result, Res} ->
{iq, ID, result, XMLNS,
[{xmlelement, "query",
[{"xmlns", XMLNS}],
Res
}]};
{error, Code, Desc} ->
{iq, ID, error, XMLNS,
[SubEl, {xmlelement, "error",
[{"code", Code}],
[{xmlcdata, Desc}]}]}
end
end;
_ ->
{iq, ID, error, XMLNS,
[SubEl, {xmlelement, "error",
[{"code", "405"}],
[{xmlcdata, "Not Allowed"}]}]}
end;
get ->
Node =
string:tokens(xml:get_tag_attr_s("node", SubEl), "/"),
case get_form(Node, Lang) of
{result, Res} ->
{iq, ID, result, XMLNS,
[{xmlelement, "query", [{"xmlns", XMLNS}],
Res
}]};
{error, Code, Desc} ->
{iq, ID, error, XMLNS,
[SubEl, {xmlelement, "error",
[{"code", Code}],
[{xmlcdata, Desc}]}]}
end
end
end.
-define(TLFIELD(Type, Label, Var),
{xmlelement, "field", [{"type", Type},
{"label", translate:translate(Lang, Label)},
{"var", Var}], []}).
-define(TABLEFIELD(Table, Val),
{xmlelement, "field", [{"type", "list-single"},
{"label", atom_to_list(Table)},
{"var", atom_to_list(Table)}],
[{xmlelement, "value", [], [{xmlcdata, atom_to_list(Val)}]},
{xmlelement, "option", [{"label",
translate:translate(Lang, "RAM copy")}],
[{xmlelement, "value", [], [{xmlcdata, "ram_copies"}]}]},
{xmlelement, "option", [{"label",
translate:translate(Lang,
"RAM and disc copy")}],
[{xmlelement, "value", [], [{xmlcdata, "disc_copies"}]}]},
{xmlelement, "option", [{"label",
translate:translate(Lang, "Disk copy")}],
[{xmlelement, "value", [], [{xmlcdata, "disc_only_copies"}]}]},
{xmlelement, "option", [{"label",
translate:translate(Lang, "Remote copy")}],
[{xmlelement, "value", [], [{xmlcdata, "unknown"}]}]}
]}).
get_form(["running nodes", ENode, "DB"], Lang) ->
case search_running_node(ENode) of
false ->
{error, "404", "Not Found"};
Node ->
case rpc:call(Node, mnesia, system_info, [tables]) of
{badrpc, Reason} ->
{error, "500", "Internal Server Error"};
Tables ->
{result, [{xmlelement, "title", [],
[{xmlcdata,
translate:translate(
Lang, "DB Tables Configuration")}]},
{xmlelement, "instructions", [],
[{xmlcdata,
translate:translate(
Lang, "Choose storage type of tables")}]} |
lists:map(
fun(Table) ->
case rpc:call(Node,
mnesia,
table_info,
[Table, storage_type]) of
{badrpc, _} ->
?TABLEFIELD(Table, unknown);
Type ->
?TABLEFIELD(Table, Type)
end
end, Tables)
]}
end
end;
get_form(_, Lang) ->
{error, "503", "Service Unavailable"}.
set_form(["running nodes", ENode, "DB"], Lang, XData) ->
case search_running_node(ENode) of
false ->
{error, "404", "Not Found"};
Node ->
lists:foreach(
fun({SVar, SVals}) ->
% We believe that this allowed only for good peoples
Table = list_to_atom(SVar),
Type = case SVals of
["unknown"] -> unknown;
["ram_copies"] -> ram_copies;
["disc_copies"] -> disc_copies;
["disc_only_copies"] -> disc_only_copies;
_ -> false
end,
if
Type == false ->
ok;
Type == unknown ->
mnesia:del_table_copy(Table, Node);
true ->
case mnesia:add_table_copy(Table, Node, Type) of
{aborted, _} ->
mnesia:change_table_copy_type(
Table, Node, Type);
_ ->
ok
end
end
end, XData),
{result, []}
end;
set_form(_, Lang, XData) ->
{error, "503", "Service Unavailable"}.
search_running_node(SNode) ->
search_running_node(SNode, mnesia:system_info(running_db_nodes)).
search_running_node(_, []) ->
false;
search_running_node(SNode, [Node | Nodes]) ->
case atom_to_list(Node) of
SNode ->
Node;
_ ->
search_running_node(SNode, Nodes)
end.

View File

@ -106,6 +106,13 @@ process_local_iq_info(From, To, {iq, ID, Type, XMLNS, SubEl}) ->
feature_to_xml({?NS_STATS}) feature_to_xml({?NS_STATS})
] ]
}]}; }]};
["running nodes", ENode, "DB"] ->
{iq, ID, result, XMLNS, [{xmlelement,
"query",
[{"xmlns", ?NS_DISCO_INFO}],
[feature_to_xml({?NS_XDATA})
]
}]};
_ -> _ ->
{iq, ID, error, XMLNS, {iq, ID, error, XMLNS,
[SubEl, {xmlelement, "error", [SubEl, {xmlelement, "error",
@ -122,7 +129,7 @@ domain_to_xml(Domain) ->
{xmlelement, "item", [{"jid", Domain}], []}. {xmlelement, "item", [{"jid", Domain}], []}.
-define(TOP_NODE(Name, Node), -define(NODE(Name, Node),
{xmlelement, "item", {xmlelement, "item",
[{"jid", Server}, [{"jid", Server},
{"name", translate:translate(Lang, Name)}, {"name", translate:translate(Lang, Name)},
@ -135,11 +142,11 @@ get_local_items([], Server, Lang) ->
ejabberd_router:dirty_get_all_routes()), ejabberd_router:dirty_get_all_routes()),
{result, {result,
Domains ++ Domains ++
[?TOP_NODE("Online Users", "online users"), [?NODE("Online Users", "online users"),
?TOP_NODE("All Users", "all users"), ?NODE("All Users", "all users"),
?TOP_NODE("Outgoing S2S connections", "outgoing s2s"), ?NODE("Outgoing S2S connections", "outgoing s2s"),
?TOP_NODE("Running Nodes", "running nodes"), ?NODE("Running Nodes", "running nodes"),
?TOP_NODE("Stopped Nodes", "stopped nodes") ?NODE("Stopped Nodes", "stopped nodes")
]}; ]};
get_local_items(["online users"], Server, Lang) -> get_local_items(["online users"], Server, Lang) ->
@ -157,7 +164,11 @@ get_local_items(["running nodes"], Server, Lang) ->
get_local_items(["stopped nodes"], Server, Lang) -> get_local_items(["stopped nodes"], Server, Lang) ->
{result, get_stopped_nodes(Lang)}; {result, get_stopped_nodes(Lang)};
get_local_items(["running nodes", _], Server, Lang) -> get_local_items(["running nodes", ENode], Server, Lang) ->
{result,
[?NODE("DB", "running nodes/" ++ ENode ++ "/DB")]};
get_local_items(["running nodes", ENode, "DB"], Server, Lang) ->
{result, []}; {result, []};
get_local_items(_, _, _) -> get_local_items(_, _, _) ->