XMPP транспорт в аську

Я пытаюсь отправлять сообщения в icq через jabber-транспорт. Я пытался использовать код из этого ответа транспорта XMPP в другой протокол, но я получил это сообщение:

DEBUG -- : SENDING:
    <message to='12345@icq.jabber.blahblah.ru' xmlns='jabber:client'><body>test
 message from robot</body></message>
=> nil
DEBUG -- : RECEIVED:
    <message from='12345@icq.jabber.blahblah.ru' to='myjit@blahblah.ru/83076
14161416233482839674' type='error'><error code='401' type='auth'><not-authorized
 xmlns='urn:ietf:params:xml:ns:xmpp-stanzas'/><text xmlns='urn:ietf:params:xml:n
s:xmpp-stanzas'>Error. You must log into the transport before sending messages.<
/text></error><body>test message from robot</body></message>

Пожалуйста, объясните мне: что я делаю не так? Заранее спасибо.

Вот мой код

require 'rubygems'
require 'xmpp4r/client'
include Jabber

Jabber.debug = true
jid = JID::new('myjit@blahblah.ru')
pass = 'pwd'
server = 'jabber.blahblah.ru'
port = '5223'
subj = 'Nagios notification'
user = '12345@icq.jabber.blahblah.ru'
text = 'AAAA AAAA AAAA'
cl = Jabber::Client::new(jid)
cl.use_ssl = true
cl.connect(server,port)
cl.auth(pass) 

#connect to transport
reg=Jabber::Iq.new_register "54321", "pwd2"
reg.to="icq.jabber.blahblah.ru"
cl.send reg

mes = Message::new(user,text)
cl.send(mes)
cl.close()

Обновленный код:

cl.connect(server,port)
cl.auth(pass)

# sending initial presence
p = Jabber::Presence.new
cl.send p

mes = Message::new(user,text)
mes.type = :chat

cl.send(mes)
cl.close()

возвращает:

D, [2014-11-18T19:01:35.986182 #8084] DEBUG -- : SENDING:
    <presence xmlns='jabber:client'/>
=> nil
irb(main):027:0> D, [2014-11-18T19:01:36.048980 #8084] DEBUG -- : RECEIVED:
    <presence from='icq.jabber.blahblah.ru' to='myjit@blahblah.ru' type='subscri
be'><status/></presence>

и до сих пор не работает

1 ответ

Вам нужно только зарегистрировать транспорт только в первый раз, затем вам нужно отправить первоначальное присутствие после создания сеанса.

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