Can't send a group message - Error 400 - Modify - BadRequest

4.6k Views Asked by At

The user is online, inside the room, can listen but it cannot send any message. Why?

I am using JAXL in PHP!

XML Message:

<presence xmlns="jabber:client" id="3">
    <status>available!</status>
    <show>dnd</show>
    <priority>10</priority>
</presence>
<presence
    xmlns="jabber:client" 
    from="bot@peoplebus/jaxl#notificator" 
    to="[email protected]/bot" 
    id="4">
    <x xmlns="http://jabber.org/protocol/muc">
        <history maxstanzas="0" seconds="0"></history>
    </x>
</presence>
<message 
    xmlns="jabber:client" 
    type="groupchat" 
    to="[email protected]/bot" 
    from="bot@peoplebus/jaxl#notificator">
    <body>teste</body>
</message>

Error:

jaxl_socket_client:189 - 2014-03-07 23:09:59 - or"/></x></presence>
<presence from="[email protected]/bot" to="bot@peoplebus/jaxl#notificator" id="4">
  <x xmlns="http://jabber.org/protocol/muc#user">
    <item jid="bot@peoplebus/jaxl#notificator" affiliation="none" role="participant"/>
  </x>
</presence>
<message type="groupchat" from="[email protected]" to="bot@peoplebus/jaxl#notificator">
  <body>Esta sala permite anônimos.</body>
  <x xmlns="http://jabber.org/protocol/muc#user"><status code="100"/></x>
</message>
<message type="error" to="bot@peoplebus/jaxl#notificator" from="[email protected]/bot">
  <body>teste</body>
  <error code="400" type="modify">
    <bad-request xmlns="urn:ietf:params:xml:ns:xmpp-stanzas"/>
  </error>
</message>

Here is a part of debug (just with what I think that is important):

jaxl_socket_client:95 - 2014-03-07 23:09:59 - trying tcp://10.208.4.180:5222
jaxl_socket_client:104 - 2014-03-07 23:09:59 - connected to tcp://10.208.4.180:5222
jaxl_socket_client:188 - 2014-03-07 23:09:59 - read 182/182 of data
jaxl_socket_client:189 - 2014-03-07 23:09:59 - <?xml version='1.0' encoding='UTF-8'?><stream:stream xmlns:stream="http://etherx.jabber.org/streams" xmlns="jabber:client" from="peoplebus" id="4453b273" xml:lang="en" version="1.0">
jaxl_socket_client:188 - 2014-03-07 23:09:59 - read 51/719 of data
jaxl_socket_client:189 - 2014-03-07 23:09:59 - <success xmlns="urn:ietf:params:xml:ns:xmpp-sasl"/>
jaxl_socket_client:201 - 2014-03-07 23:09:59 - sent 178/440 of data
jaxl_socket_client:202 - 2014-03-07 23:09:59 - <stream:stream xmlns:stream="http://etherx.jabber.org/streams" version="1.0" to="peoplebus#" xmlns="jabber:client" xml:lang="en" xmlns:xml="http://www.w3.org/XML/1998/namespace">
jaxl_socket_client:188 - 2014-03-07 23:09:59 - read 411/1130 of data
jaxl_socket_client:189 - 2014-03-07 23:09:59 - <?xml version='1.0' encoding='UTF-8'?><stream:stream xmlns:stream="http://etherx.jabber.org/streams" xmlns="jabber:client" from="peoplebus" id="4453b273" xml:lang="en" version="1.0"><stream:features><compression xmlns="http://jabber.org/features/compress"><method>zlib</method></compression><bind xmlns="urn:ietf:params:xml:ns:xmpp-bind"/><session xmlns="urn:ietf:params:xml:ns:xmpp-session"/></stream:features>
jaxl_socket_client:201 - 2014-03-07 23:09:59 - sent 140/580 of data
jaxl_socket_client:202 - 2014-03-07 23:09:59 - <iq xmlns="jabber:client" type="set" id="1"><bind xmlns="urn:ietf:params:xml:ns:xmpp-bind"><resource>jaxl#notificator</resource></bind></iq>
jaxl_socket_client:188 - 2014-03-07 23:09:59 - read 149/1279 of data
jaxl_socket_client:189 - 2014-03-07 23:09:59 - <iq type="result" id="1" to="peoplebus/4453b273"><bind xmlns="urn:ietf:params:xml:ns:xmpp-bind"><jid>bot@peoplebus/jaxl#notificator</jid></bind></iq>
jaxl_socket_client:201 - 2014-03-07 23:09:59 - sent 112/692 of data
jaxl_socket_client:202 - 2014-03-07 23:09:59 - <iq xmlns="jabber:client" type="set" id="2"><session xmlns="urn:ietf:params:xml:ns:xmpp-session"></session></iq>
jaxl_socket_client:188 - 2014-03-07 23:09:59 - read 62/1341 of data
jaxl_socket_client:189 - 2014-03-07 23:09:59 - <iq type="result" id="2" to="bot@peoplebus/jaxl#notificator"/>
notificator:43 - 2014-03-07 23:09:59 - got on_auth_success cb, jid bot@peoplebus/jaxl#notificator
jaxl_exception:66 - 2014-03-07 23:09:59 - error handler called with 8, Undefined index: id, /var/www/jaxl/xmpp/xmpp_stanza.php, 81
jaxl_socket_client:201 - 2014-03-07 23:09:59 - sent 484/1176 of data
jaxl_socket_client:202 - 2014-03-07 23:09:59 - <presence xmlns="jabber:client" id="3"><status>available!</status><show>dnd</show><priority>10</priority></presence><presence xmlns="jabber:client" from="bot@peoplebus/jaxl#notificator" to="[email protected]/bot" id="4"><x xmlns="http://jabber.org/protocol/muc"><history maxstanzas="0" seconds="0"></history></x></presence><message xmlns="jabber:client" type="groupchat" to="[email protected]/bot" from="bot@peoplebus/jaxl#notificator"><body>teste</body></message>
jaxl_socket_client:188 - 2014-03-07 23:09:59 - read 168/1509 of data
jaxl_socket_client:189 - 2014-03-07 23:09:59 - <presence id="3" from="bot@peoplebus/jaxl#notificator" to="bot@peoplebus/jaxl#notificator"><status>available!</status><show>dnd</show><priority>10</priority></presence>
jaxl_socket_client:188 - 2014-03-07 23:09:59 - read 1024/2533 of data
jaxl_socket_client:189 - 2014-03-07 23:09:59 - <presence from="pidgin@peoplebus/fbaff75c" to="bot@peoplebus/jaxl#notificator"><priority>1</priority><c xmlns="http://jabber.org/protocol/caps" node="http://pidgin.im/" hash="sha-1" ver="I22W7CegORwdbnu0ZiQwGpxr0Go="/><x xmlns="vcard-temp:x:update"><photo/></x></presence><message to="bot@peoplebus/jaxl#notificator" from="pidgin@peoplebus" id="pidgin@peoplebus__bot@peoplebus__52D8K"><event xmlns="http://jabber.org/protocol/pubsub#event"><items node="http://jabber.org/protocol/tune"><item id="4ebd50d9-2c64-4c70-9fe5-45b8cffa5fda3"><tune xmlns="http://jabber.org/protocol/tune"/></item></items></event><delay xmlns="urn:xmpp:delay" stamp="2014-03-07T22:40:10.155Z"/></message><presence to="bot@peoplebus/jaxl#notificator" from="[email protected]/pidgin"><priority>1</priority><c xmlns="http://jabber.org/protocol/caps" node="http://pidgin.im/" hash="sha-1" ver="I22W7CegORwdbnu0ZiQwGpxr0Go="/><x xmlns="http://jabber.org/protocol/muc#user"> ...
jaxl_fsm:61 - 2014-03-07 23:09:59 - calling state handler 'logged_in' for incoming event 'stanza_cb'
jaxl_fsm:71 - 2014-03-07 23:09:59 - current state 'logged_in'
jaxl_socket_client:188 - 2014-03-07 23:09:59 - read 698/3231 of data
jaxl_socket_client:189 - 2014-03-07 23:09:59 - or"/></x></presence><presence from="[email protected]/bot" to="bot@peoplebus/jaxl#notificator" id="4"><x xmlns="http://jabber.org/protocol/muc#user"><item jid="bot@peoplebus/jaxl#notificator" affiliation="none" role="participant"/></x></presence><message type="groupchat" from="[email protected]" to="bot@peoplebus/jaxl#notificator"><body>Esta sala permite anônimos.</body><x xmlns="http://jabber.org/protocol/muc#user"><status code="100"/></x></message><message type="error" to="bot@peoplebus/jaxl#notificator" from="[email protected]/bot"><body>teste</body><error code="400" type="modify"><bad-request xmlns="urn:ietf:params:xml:ns:xmpp-stanzas"/></error></message>
jaxl_fsm:61 - 2014-03-07 23:09:59 - calling state handler 'logged_in' for incoming event 'stanza_cb'
jaxl_exception:66 - 2014-03-07 23:09:59 - error handler called with 8, Undefined index: type, /var/www/jaxl/xmpp/xmpp_stanza.php, 81
1

There are 1 best solutions below

1
On

Found the problem here:

<message 
    xmlns="jabber:client" 
    type="groupchat" 
    to="[email protected]/bot" 
    from="bot@peoplebus/jaxl#notificator">
    <body>teste</body>
</message>

If I want to send a message to all ocuppants:

<message
    from='[email protected]/pda'
    id='hysf1v37'
    to='[email protected]'
    type='groupchat'>
  <body>Harpier cries: 'tis time, 'tis time.</body>
</message>

I shouldn't use to="[email protected]/bot".

Right is: to="[email protected]"

According with:

http://www.xmpp.org/extensions/xep-0045.html#privatemessage

If the sender attempts to send a private message of type "groupchat" to a particular occupant, the service MUST refuse to deliver the message (since the recipient's client would expect in-room messages to be of type "groupchat") and return a <bad-request/> error to the sender:

Example 48. Occupant Attempts to Send a Message of Type "Groupchat" to a Particular Occupant

<message
    from='[email protected]/laptop'
    id='bx71f29k'
    to='[email protected]/firstwitch'
    type='groupchat'>
  <body>I'll give thee a wind.</body>
</message>

<message
    from='[email protected]/firstwitch'
    id='bx71f29k'
    to='[email protected]/laptop'
    type='error'>
  <body>I'll give thee a wind.</body>
  <error by='[email protected]' type='modify'>
    <bad-request xmlns='urn:ietf:params:xml:ns:xmpp-stanzas'/>
  </error>
</message>