Updated to fix iq:version stats
This commit is contained in:
parent
e99866d835
commit
4d3acc1637
|
@ -14,6 +14,7 @@
|
||||||
-behaviour(gen_mod).
|
-behaviour(gen_mod).
|
||||||
|
|
||||||
-export([start/2, loop/1, stop/1, mod_opt_type/1, get_statistic/2,
|
-export([start/2, loop/1, stop/1, mod_opt_type/1, get_statistic/2,
|
||||||
|
received_response/3,
|
||||||
%% Commands
|
%% Commands
|
||||||
getstatsdx/1, getstatsdx/2,
|
getstatsdx/1, getstatsdx/2,
|
||||||
get_top_users/2,
|
get_top_users/2,
|
||||||
|
@ -29,7 +30,7 @@
|
||||||
|
|
||||||
-include("ejabberd.hrl").
|
-include("ejabberd.hrl").
|
||||||
-include("ejabberd_commands.hrl").
|
-include("ejabberd_commands.hrl").
|
||||||
-include("jlib.hrl").
|
-include("xmpp.hrl").
|
||||||
-include("logger.hrl").
|
-include("logger.hrl").
|
||||||
-include("mod_roster.hrl").
|
-include("mod_roster.hrl").
|
||||||
-include("ejabberd_http.hrl").
|
-include("ejabberd_http.hrl").
|
||||||
|
@ -744,8 +745,7 @@ ms_to_time(T) ->
|
||||||
user_login(#{user := User, lserver := Host, resource := Resource} = State) ->
|
user_login(#{user := User, lserver := Host, resource := Resource} = State) ->
|
||||||
ets:update_counter(table_name(server), {user_login, server}, 1),
|
ets:update_counter(table_name(server), {user_login, server}, 1),
|
||||||
ets:update_counter(table_name(Host), {user_login, Host}, 1),
|
ets:update_counter(table_name(Host), {user_login, Host}, 1),
|
||||||
%% TODO: rewrite using ejabberd_router:route_iq
|
request_iqversion(User, Host, Resource),
|
||||||
%% request_iqversion(User, Host, Resource).
|
|
||||||
State.
|
State.
|
||||||
|
|
||||||
|
|
||||||
|
@ -780,16 +780,22 @@ user_logout(User, Host, Resource, _Status) ->
|
||||||
end.
|
end.
|
||||||
|
|
||||||
request_iqversion(User, Host, Resource) ->
|
request_iqversion(User, Host, Resource) ->
|
||||||
From = jlib:make_jid(<<"">>, Host, list_to_binary(atom_to_list(?MODULE))),
|
From = jid:make(<<"">>, Host, list_to_binary(atom_to_list(?MODULE))),
|
||||||
FromStr = jlib:jid_to_string(From),
|
To = jid:make(User, Host, Resource),
|
||||||
To = jlib:make_jid(User, Host, Resource),
|
Query = #xmlel{name = <<"query">>, attrs = [{<<"xmlns">>, ?NS_VERSION}]},
|
||||||
ToStr = jlib:jid_to_string(To),
|
IQ = #iq{type = get,
|
||||||
Packet = {xmlel,<<"iq">>,
|
from = From,
|
||||||
[{<<"from">>,FromStr}, {<<"to">>,ToStr}, {<<"type">>,<<"get">>},
|
to = To,
|
||||||
{<<"id">>, list_to_binary("statsdx"++randoms:get_string())}],
|
id = randoms:get_string(),
|
||||||
[{xmlel, <<"query">>,
|
sub_els = [Query]},
|
||||||
[{<<"xmlns">>,<<"jabber:iq:version">>}], []}]},
|
HandleResponse = fun(#iq{type = result} = IQr) ->
|
||||||
ejabberd_local:route(From, To, Packet).
|
spawn(?MODULE, received_response,
|
||||||
|
[To, From, IQr]);
|
||||||
|
(R) ->
|
||||||
|
?INFO_MSG("Unexpected response: ~n~p", [R]),
|
||||||
|
ok % Hmm.
|
||||||
|
end,
|
||||||
|
ejabberd_router:route_iq(IQ, HandleResponse).
|
||||||
|
|
||||||
%% cuando el virtualJID recibe una respuesta iqversion,
|
%% cuando el virtualJID recibe una respuesta iqversion,
|
||||||
%% almacenar su JID/USR + client + OS en una tabla
|
%% almacenar su JID/USR + client + OS en una tabla
|
||||||
|
@ -798,13 +804,13 @@ received_response(From, _To, El) ->
|
||||||
catch
|
catch
|
||||||
_:_ -> ok
|
_:_ -> ok
|
||||||
end.
|
end.
|
||||||
received_response(From, {xmlel, <<"iq">>, Attrs, Elc}) ->
|
received_response(From, #iq{type = Type, lang = Lang1, sub_els = Elc}) ->
|
||||||
User = From#jid.luser,
|
User = From#jid.luser,
|
||||||
Host = From#jid.lserver,
|
Host = From#jid.lserver,
|
||||||
Resource = From#jid.lresource,
|
Resource = From#jid.lresource,
|
||||||
|
|
||||||
<<"result">> = fxml:get_attr_s(<<"type">>, Attrs),
|
result = Type,
|
||||||
Lang = case fxml:get_attr_s(<<"xml:lang">>, Attrs) of
|
Lang = case Lang1 of
|
||||||
<<"">> -> "unknown";
|
<<"">> -> "unknown";
|
||||||
L -> binary_to_list(L)
|
L -> binary_to_list(L)
|
||||||
end,
|
end,
|
||||||
|
@ -841,7 +847,8 @@ received_response(From, {xmlel, <<"iq">>, Attrs, Elc}) ->
|
||||||
ets:insert(TableHost, {{session, JID}, Client_id, OS_id, Lang, ConnType, Client, Version, OS}).
|
ets:insert(TableHost, {{session, JID}, Client_id, OS_id, Lang, ConnType, Client, Version, OS}).
|
||||||
|
|
||||||
get_connection_type(User, Host, Resource) ->
|
get_connection_type(User, Host, Resource) ->
|
||||||
[_Node, {conn, Conn}, _IP] = ejabberd_sm:get_user_info(User, Host, Resource),
|
UserInfo = ejabberd_sm:get_user_info(User, Host, Resource),
|
||||||
|
{conn, Conn} = lists:keyfind(conn, 1, UserInfo),
|
||||||
Conn.
|
Conn.
|
||||||
|
|
||||||
update_counter_create(Table, Element, C) ->
|
update_counter_create(Table, Element, C) ->
|
||||||
|
|
Loading…
Reference in New Issue