Search code examples
asterisksiphttp-status-code-415

Asterisk incoming message gives: 415 unsupported media type


Me and my project group are trying to set up a PBX with asterisk. We've managed to let it work with just SIP calls and that works perfect. But once we want to try add an XML message to it Asterisk doesn't recognize it and gives "415 Unsupported Media Type". It seems like the call isn't even making it through it is getting rejected immediately.

We have tried to find the piece of code where this gets handled but didn't found anything.

The SIP message that is send to Asterisk looks like this:

Request-Line: MESSAGE sip:[email protected] SIP/2.0
  Method: MESSAGE
  Request-URI: sip:[email protected]
  Via: SIP/2.0/UDP xxx.xxx.xxx.111:5060;branch=z9hG4bK-3f138a53
  To: <sip:[email protected]>
  From: <sip:[email protected]>;tag=7a82b127
  Call-ID: [email protected]
  CSeq: 104 MESSAGE
  Max-Forwards: 70
  User-Agent: CareIP 7813409 v1.2.4.0
  Content-Type: application/scaip+xml
  Content-Length: 91
Message Body
  <mrq><ref>765745670002</ref<mty>ME</mty><cid>266786</cid><dty>0005</dty><stc>0010</stc></mrq

Our question(s) is/are: Where in the code or config files can we find where asterisk decides whether this is "media type" supported or not?

Or

Does someone know how to add a media type that is not supported (yet) by Asterisk?


Solution

  • It looks like the accepted Content-Type for a Message is hard-coded, so you won't be able to do this in a config file. If you look at the function receive_message() in channels\chan_sip.c, you will see the following lines:

        if (strncmp(content_type, "text/plain", strlen("text/plain"))) { /* No text/plain attachment */
        transmit_response(p, "415 Unsupported Media Type", req); /* Good enough, or? */
    

    If you modify the strncmp() to also allow "application/scaip+xml" and recompile, it will no longer respond with the 415 Unsupported Media Type error, and you can modify the rest of the receive_message() function to suit your needs.