Custom IQ возвращает ответ об ошибке

У меня есть образец модуля, как,

-module(mod_iq_test).
-behaviour(gen_mod).
-export([start/2,
         init/2,
         stop/1,
         process_sm_iq/3
    ]).

-define(PROCNAME, ?MODULE).

-include("ejabberd.hrl").
-include("jlib.hrl").
-include("logger.hrl").

-define(NS_TEST, <<"http://jabber.org/protocol/test">>).

start(Host, Opts) ->
    ?INFO_MSG("Loading module 'mod_iqtest' v.01", []),
    ok.

init(Host, _Opts) ->
    IQDisc = gen_mod:get_opt(iqdisc, _Opts, fun(A) -> A end, one_queue),
    gen_iq_handler:add_iq_handler(ejabberd_sm, Host, ?NS_TEST, ?MODULE, process_sm_iq, IQDisc),
    ?INFO_MSG("added iq handlers 'mod_iqtest' v.01", []),
    ok.

stop(Host) ->
    gen_iq_handler:remove_iq_handler(ejabberd_sm, Host, ?NS_TEST),
    ?INFO_MSG("Stoping module 'mod_iqtest' ", []),
    ok.

process_sm_iq(_From, _To, IQ) ->
    ?INFO_MSG("Processing IQ Get query:~n ~p", [IQ]),
    IQ#iq{type = result, sub_el = [{xmlel, <<"value">>, [], [{xmlcdata, <<"Hello World of Testing.">>}]}]}.

И при отправке IQ как,

<iq type='get' id='aaa8821'>
  <query xmlns='http://jabber.org/protocol/test'/>
</iq>

Выдает ошибку как,

<iq xml:lang="en" from="admin@localhost" id="aaa8821" type="error" to="admin@localhost/durai">
<query xmlns="http://jabber.org/protocol/test"/>
<error code="503" type="cancel">
<service-unavailable xmlns="urn:ietf:params:xml:ns:xmpp-stanzas"/>
<text xmlns="urn:ietf:params:xml:ns:xmpp-stanzas" xml:lang="en">No module is handling this query</text>
</error>
</iq>

В ejabberd_sm.erl при поиске ets он возвращает [],

ets:lookup(sm_iqtable, {Host, XMLNS})

Мой пользовательский iq не вызывал функцию handle_cast в ejabberd_sm.erl

0 ответов

Другие вопросы по тегам