Привет, я пытаюсь запустить локальный экземпляр ejabberd и подключиться к нему с помощью Adium - я могу это сделать, но при попытке присоединиться к групповому чату возникают проблемы.
Я попытался создать комнату, запустив ejabberdctl create_room room1 localhost localhost
и подключившись через Adium, но вот сообщения об ошибках, которые я получаю:
2018-10-19 22:48:51.550 [debug] <0.2234.0>@xmpp_socket:parse:374 (tcp|<0.2234.0>)
Received XML on stream = <<"
<presence to='room1@localhost/dan'>
<c xmlns='http://jabber.org/protocol/caps'
node='http://pidgin.im/' hash='sha-1'
ver='DdnydQG7RGhP9E3k9Sf+b+bF0zo='/>
<x xmlns='http://jabber.org/protocol/muc'/>
</presence>
">>
а также:
#presence{id = <<>>,type = available,lang = <<"en">>,
from = #jid{user = <<"danmiller">>,server = <<"localhost">>,
resource = <<"8c859086572c">>,luser = <<"danmiller">>,
lserver = <<"localhost">>,
lresource = <<"8c859086572c">>},
to = #jid{user = <<"room1">>,server = <<"localhost">>,
resource = <<"dan">>,luser = <<"room1">>,
lserver = <<"localhost">>,lresource = <<"dan">>},
show = undefined,status = [],priority = undefined,
sub_els = [#xmlel{name = <<"c">>,
attrs = [{<<"xmlns">>,
<<"http://jabber.org/protocol/caps">>},
{<<"node">>,<<"http://pidgin.im/">>},
{<<"hash">>,<<"sha-1">>},
{<<"ver">>,
<<"DdnydQG7RGhP9E3k9Sf+b+bF0zo = ">>}],
children = []},
#xmlel{name = <<"x">>,
attrs = [{<<"xmlns">>,
<<"http://jabber.org/protocol/muc">>}],
children = []},
#vcard_xupdate{hash = <<>>}],
meta = #{ip => {0,0,0,0,0,0,0,1}}}
2018-10-19 22:48:51.552 [debug] <0.2234.0>@ejabberd_local:do_route:141 local route:
#presence{id = <<>>,type = available,lang = <<"en">>,
from = #jid{user = <<"danmiller">>,server = <<"localhost">>,
resource = <<"8c859086572c">>,luser = <<"danmiller">>,
lserver = <<"localhost">>,
lresource = <<"8c859086572c">>},
to = #jid{user = <<"room1">>,server = <<"localhost">>,
resource = <<"dan">>,luser = <<"room1">>,
lserver = <<"localhost">>,lresource = <<"dan">>},
show = undefined,status = [],priority = undefined,
sub_els = [#xmlel{name = <<"c">>,
attrs = [{<<"xmlns">>,
<<"http://jabber.org/protocol/caps">>},
{<<"node">>,<<"http://pidgin.im/">>},
{<<"hash">>,<<"sha-1">>},
{<<"ver">>,
<<"DdnydQG7RGhP9E3k9Sf+b+bF0zo = ">>}],
children = []},
#xmlel{name = <<"x">>,
attrs = [{<<"xmlns">>,
<<"http://jabber.org/protocol/muc">>}],
children = []},
#vcard_xupdate{hash = <<>>}],
meta = #{ip => {0,0,0,0,0,0,0,1}}}
2018-10-19 22:48:51.552 [debug] <0.2234.0>@ejabberd_sm:do_route:651 processing packet to full JID:
#presence{id = <<>>,type = available,lang = <<"en">>,
from = #jid{user = <<"danmiller">>,server = <<"localhost">>,
resource = <<"8c859086572c">>,luser = <<"danmiller">>,
lserver = <<"localhost">>,
lresource = <<"8c859086572c">>},
to = #jid{user = <<"room1">>,server = <<"localhost">>,
resource = <<"dan">>,luser = <<"room1">>,
lserver = <<"localhost">>,lresource = <<"dan">>},
show = undefined,status = [],priority = undefined,
sub_els = [#xmlel{name = <<"c">>,
attrs = [{<<"xmlns">>,
<<"http://jabber.org/protocol/caps">>},
{<<"node">>,<<"http://pidgin.im/">>},
{<<"hash">>,<<"sha-1">>},
{<<"ver">>,
<<"DdnydQG7RGhP9E3k9Sf+b+bF0zo = ">>}],
children = []},
#xmlel{name = <<"x">>,
attrs = [{<<"xmlns">>,
<<"http://jabber.org/protocol/muc">>}],
children = []},
#vcard_xupdate{hash = <<>>}],
meta = #{ip => {0,0,0,0,0,0,0,1}}}
2018-10-19 22:48:51.553 [debug] <0.2234.0>@ejabberd_sm:do_route:664 dropping presence to unavailable resource:
#presence{id = <<>>,type = available,lang = <<"en">>,
from = #jid{user = <<"danmiller">>,server = <<"localhost">>,
resource = <<"8c859086572c">>,luser = <<"danmiller">>,
lserver = <<"localhost">>,
lresource = <<"8c859086572c">>},
to = #jid{user = <<"room1">>,server = <<"localhost">>,
resource = <<"dan">>,luser = <<"room1">>,
lserver = <<"localhost">>,lresource = <<"dan">>},
show = undefined,status = [],priority = undefined,
sub_els = [#xmlel{name = <<"c">>,
attrs = [{<<"xmlns">>,
<<"http://jabber.org/protocol/caps">>},
{<<"node">>,<<"http://pidgin.im/">>},
{<<"hash">>,<<"sha-1">>},
{<<"ver">>,
<<"DdnydQG7RGhP9E3k9Sf+b+bF0zo = ">>}],
children = []},
#xmlel{name = <<"x">>,
attrs = [{<<"xmlns">>,
<<"http://jabber.org/protocol/muc">>}],
children = []},
#vcard_xupdate{hash = <<>>}],
meta = #{ip => {0,0,0,0,0,0,0,1}}}
Я считаю, что у меня конфигурация настроена правильно, с modules.mod_muc.access: all
Что мне не хватает?
Я нашел ответ, обратив внимание на документацию к модулю mod_muc
:
Module options:
host: HostName: This option defines the Jabber ID of the service. If the host
option is not specified, the Jabber ID will be the hostname of the virtual host
with the prefix ‘conference.’. The keyword “@HOST@” is replaced at start time with
the real virtual host name.
Я пытался подключиться и создать комнату на room1@localhost
, когда мне нужно было либо подключиться к [email protected]
, либо добавить host: localhost
в мою конфигурацию в разделе mod_muc
.
Если вы пропустили это: когда клиент пытается присоединиться к комнате, которой не существует, она будет создана немедленно, нет необходимости создавать ее заранее с помощью команды. Конечно, у этого клиента должно быть разрешение на создание комнат (обратите внимание на опцию access_create).