When client replies error, try Xabber detection, and report others in log

This commit is contained in:
Badlop 2021-05-21 19:39:25 +02:00
parent 2e60ec7079
commit 5b44231a37
1 changed files with 38 additions and 19 deletions

View File

@ -813,7 +813,7 @@ request_iqversion(User, Host, Resource) ->
to = To,
id = p1_rand:get_string(),
sub_els = [Query]},
HandleResponse = fun(#iq{type = result} = IQr) ->
HandleResponse = fun(#iq{type = Type} = IQr) when (Type == result) or (Type == error) ->
spawn(?MODULE, received_response,
[To, From, IQr]);
(R) ->
@ -829,32 +829,51 @@ received_response(From, _To, El) ->
catch
_:_ -> ok
end.
received_response(From, #iq{type = Type, lang = Lang1, sub_els = Elc}) ->
User = From#jid.luser,
Host = From#jid.lserver,
received_response(From, #iq{type = error, lang = Lang1, sub_els = Elc} = Iq)
when [{xmlel,<<"error">>,
[{<<"type">>,<<"modify">>}],
[{xmlel,<<"not-acceptable">>,
[{<<"xmlns">>,<<"urn:ietf:params:xml:ns:xmpp-stanzas">>}],
[]}]}] == Elc ->
Resource = From#jid.lresource,
result = Type,
Lang = case Lang1 of
<<"">> -> "unknown";
L -> binary_to_list(L)
{Client_id, OS_id} =
case binary:split(Resource, [<<"-">>, <<"_">>], [global]) of
[<<"xabber">>, <<"android">>, _] ->
{xabber, android};
[<<"Xabber">> | _] ->
{xabber, unknown};
_ ->
?INFO_MSG("statsdx unknown client: ~n~p", [Iq]),
{unknown, unknown}
end,
TableHost = table_name(Host),
TableServer = table_name(server),
update_counter_create(TableHost, {lang, Host, Lang}, 1),
update_counter_create(TableServer, {lang, server, Lang}, 1),
received_response(From, Client_id, OS_id, Lang1,
"unknown", "unknown", "unknown");
received_response(From, #iq{type = result, lang = Lang1, sub_els = Elc}) ->
[El] = fxml:remove_cdata(Elc),
{xmlel, _, Attrs2, _Els2} = El,
?NS_VERSION = fxml:get_attr_s(<<"xmlns">>, Attrs2),
Client = get_tag_cdata_subtag(El, <<"name">>),
Version = get_tag_cdata_subtag(El, <<"version">>),
OS = get_tag_cdata_subtag(El, <<"os">>),
{Client_id, OS_id} = identify(Client, OS),
received_response(From, Client_id, OS_id, Lang1, Client, Version, OS);
received_response(From, #iq{type = error, lang = Lang1} = Iq) ->
?INFO_MSG("statsdx unknown client: ~n~p", [Iq]),
received_response(From, unknown, unknown, Lang1,
"unknown", "unknown", "unknown").
received_response(From, Client_id, OS_id, Lang1, Client, Version, OS) ->
User = From#jid.luser,
Host = From#jid.lserver,
Resource = From#jid.lresource,
ConnType = get_connection_type(User, Host, Resource),
Lang = case Lang1 of
<<"">> -> "unknown";
L -> binary_to_list(L)
end,
TableHost = table_name(Host),
TableServer = table_name(server),
ets:update_counter(TableHost, {client, Host, Client_id}, 1),
@ -863,13 +882,13 @@ received_response(From, #iq{type = Type, lang = Lang1, sub_els = Elc}) ->
ets:update_counter(TableServer, {os, server, OS_id}, 1),
ets:update_counter(TableHost, {conntype, Host, ConnType}, 1),
ets:update_counter(TableServer, {conntype, server, ConnType}, 1),
update_counter_create(TableHost, {lang, Host, Lang}, 1),
update_counter_create(TableServer, {lang, server, Lang}, 1),
update_counter_create(TableHost, {client_os, Host, Client_id, OS_id}, 1),
update_counter_create(TableServer, {client_os, server, Client_id, OS_id}, 1),
update_counter_create(TableHost, {client_conntype, Host, Client_id, ConnType}, 1),
update_counter_create(TableServer, {client_conntype, server, Client_id, ConnType}, 1),
JID = jid:make(User, Host, Resource),
ets:insert(TableHost, {{session, JID}, Client_id, OS_id, Lang, ConnType, Client, Version, OS}).
ets:insert(TableHost, {{session, From}, Client_id, OS_id, Lang, ConnType, Client, Version, OS}).
get_connection_type(User, Host, Resource) ->
UserInfo = ejabberd_sm:get_user_info(User, Host, Resource),