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:
parent
942fbb9fae
commit
bacbeeaaa4
1
TODO
1
TODO
@ -1,3 +1,4 @@
|
|||||||
|
admin interface
|
||||||
S2S timeouts
|
S2S timeouts
|
||||||
iq:browse(?)
|
iq:browse(?)
|
||||||
SVR DNS records
|
SVR DNS records
|
||||||
|
@ -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;
|
||||||
|
@ -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, []},
|
||||||
|
@ -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(),
|
||||||
|
@ -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;
|
||||||
_ ->
|
_ ->
|
||||||
""
|
""
|
||||||
|
@ -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
207
src/mod_configure.erl
Normal 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.
|
||||||
|
|
||||||
|
|
@ -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(_, _, _) ->
|
||||||
|
Loading…
Reference in New Issue
Block a user