ejabberd:生成自己的进程并将结果路由回客户端

问题描述 投票:0回答:1

因为ejabberd不再支持iqdisc选项。我试图创建自己的自定义队列,以处理具有自定义名称空间的所有iq-packets,并将结果返回给客户端。我能够生成自己的进程并运行功能并获得结果。但是该过程最终失败,并显示以下错误:

09:07:42.850 [error] Failed to route packet:
#iq{id = <<"5b660017-c52c-4fe8-8a56-213c1a86bc12-3">>,type = get,
    lang = <<"en">>,
    from =
        #jid{
            user = <<"check">>,server = <<"localhost">>,
            resource = <<"64195176449188261912514">>,luser = <<"check">>,
            lserver = <<"localhost">>,
            lresource = <<"64195176449188261912514">>},
    to =
        #jid{
            user = <<>>,server = <<"localhost">>,resource = <<>>,luser = <<>>,
            lserver = <<"localhost">>,lresource = <<>>},
    sub_els =
        [#xmlel{
             name = <<"....
......
.......
exception error: no try clause matching ok
   in function  gen_iq_handler:process_iq/4 (src/gen_iq_handler.erl, line 110)
   in call from ejabberd_router:do_route/1 (src/ejabberd_router.erl, line 399)
   in call from ejabberd_router:route/1 (src/ejabberd_router.erl, line 92)
   in call from ejabberd_c2s:check_privacy_then_route/2 (src/ejabberd_c2s.erl, line 842)
   in call from xmpp_stream_in:process_authenticated_packet/2 (src/xmpp_stream_in.erl, line 697)
   in call from xmpp_stream_in:handle_info/2 (src/xmpp_stream_in.erl, line 392)
   in call from p1_server:handle_msg/8 (src/p1_server.erl, line 696)
   in call from proc_lib:init_p_do_apply/3 (proc_lib.erl, line 249)

上面显示的数据包是从客户端到服务器的:对我来说,这很好。我正在使用最新的ejabberd版本:19.09.1我猜想,我无法将iq-packet响应路由回客户端吗?我在这里想念其他东西吗?这个包装对我来说似乎很好。将队列处理所有iq数据包到一个自定义名称空间,然后将响应返回给客户端的理想方式是什么,而同时又不阻塞主队列,因此ejabberd仍然可以处理其他传入数据包。 >

任何想法/指针都将不胜感激。谢谢!

因为ejabberd不再支持iqdisc选项。我试图创建自己的自定义队列,以处理具有自定义名称空间的所有iq-packets,并将结果返回给客户端。我可以...

erlang xmpp ejabberd spawn ejabberd-module
1个回答
0
投票

我知道了。产生的进程未返回期望的结果,因此请求失败。我仍在尝试弄清如何在ejabberd上一次处理多个数据包(目标到不同的名称空间),以便可以将所有数据包运行到我的自定义名称空间以在单个队列上运行。

© www.soinside.com 2019 - 2024. All rights reserved.