Чтение и форматирование строфы сообщения в ejabberd
Я занимаюсь разработкой специального модуля в ejabberd. Мне нужно извлечь содержимое тела сообщения, а также проверить, есть ли в строфе текст сообщения или нет. Вот мой фрагмент кода
-module(mod_push_generate).
-behaviour(gen_mod).
-include("logger.hrl").
-include("ejabberd_sql_pt.hrl").
-include("ejabberd_http.hrl").
-include("xmpp.hrl").
%-include("jlib.hrl").
%% gen_mod API callbacks
-export([start/2, stop/1, depends/2, mod_options/1, fetch_token/2, on_user_send_packet/1]).
start(Host,_Opts) ->
?INFO_MSG("Mod PUSH GENARATOR has been started",[]),
inets:start(),
ejabberd_hooks:add(user_send_packet, Host, ?MODULE, on_user_send_packet, 50),
ok.
stop(Host) ->
?INFO_MSG("Module has been stopped",[]),
ejabberd_hooks:delete(user_send_packet, Host, ?MODULE, on_user_send_packet, 50),
ok.
depends(_Host, _Opts) ->
[].
mod_options(_Host) ->
[].
%-spec on_user_send_packet({stanza(), ejabberd_c2s:state()}) -> {stanza(), ejabberd_c2s:state()}.
%on_user_send_packet({From, To, XML} = Pkt) ->
on_user_send_packet({#message{to = Peer} = Pkt, #{jid := JID} = C2SState}) ->
?INFO_MSG("on user send packet called from ",[Pkt]),
Els = xmpp:get_els(Pkt),
?INFO_MSG("Body: ",[Els]),
{Pkt, C2SState};
on_user_send_packet(Acc) ->
?INFO_MSG("Inside nothing box.",[]),
Acc.
Logging Pkt дает
12:41:17.956 [info] FORMAT ERROR: "on user send packet called from " [{message,<<"2fe6c6a3-e89e-4f05-ac4d-b096b75f0f32">>,chat,<<"en">>,{jid,<<"sagar">>,<<"192.168.4.69">>,<<"sagar.webApp">>,<<"sagar">>,<<"192.168.4.69">>,<<"sagar.webApp">>},{jid,<<"tony">>,<<"192.168.4.69">>,<<>>,<<"tony">>,<<"192.168.4.69">>,<<>>},[],[{text,<<>>,<<"xasXASXAS">>}],undefined,[{xmlel,<<"request">>,[{<<"xmlns">>,<<"urn:xmpp:receipts">>}],[]}],#{ip => {0,0,0,0,0,65535,49320,1093}}}]
и ведение журнала Els дает
14:04:25.906 [info] FORMAT ERROR: "Body: " [[{xmlel,<<"request">>,[{<<"xmlns">>,<<"urn:xmpp:receipts">>}],[]}]]
вторая строка показывает, что из я извлекаю компонент из строфы сообщения, единственным обнаруживаемым элементом xml является элемент "запрос". Почему в абзаце сообщения нет "основного элемента".
Скажите, пожалуйста, как я могу извлечь (или проверить наличие) текст сообщения в строфе.
Спасибо
1 ответ
Почему в абзаце сообщения нет "основного элемента".
Структура #message сохраняет содержимое тела в #message.body, а не в #message.sub_els. См. Примеры в https://docs.ejabberd.im/developer/guide/
Мне нужно извлечь содержимое тела сообщения
Попробуйте эту строку:
?INFO_MSG("Body: ~p", [ xmpp:get_text(Pkt#message.body) ]),
Он будет регистрировать такие вещи:
17:08:12.897 [info] Body: <<"hey, are you there?">>
17:08:12.926 [info] Body: <<>>
а также проверьте, есть ли в строфе текст сообщения.
Когда Тело <<>>, это означает, что у него нет тела.