[asterisk-bugs] [JIRA] (ASTERISK-27342) ARI: Error building JSON for PRI calls with Calling Party Subaddress Type NSAP

Richard Mudgett (JIRA) noreply at issues.asterisk.org
Fri Oct 13 13:47:20 CDT 2017


    [ https://issues.asterisk.org/jira/browse/ASTERISK-27342?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=239328#comment-239328 ] 

Richard Mudgett commented on ASTERISK-27342:
--------------------------------------------

{noformat}
[Oct 13 08:33:59] VERBOSE[43961] chan_dahdi.c: PRI Span: 1 < [6d 0c 01 83 30 37 38 36 31 34 34 33 34 31]
[Oct 13 08:33:59] VERBOSE[43961] chan_dahdi.c: PRI Span: 1 < Calling Party Subaddress (len=14) [ Ext: 0  Type: NSAP (X.213/ISO 8348 AD2) (0)  O: 0  '�0786144341' ]
{noformat}

6d Octet 1 (ie identifier) Calling party subaddress
0c Octet 2 (ie length) 12 more octets
01 Octet 3 (ext=0 (Octet 3 is extended to the next octet and is not defined by Q.931), Type=0-NSAP, Odd/even=0-Even Spare=1 (Q.931 does not define these bits and they are supposed to be zero))
83 Octet 3a (Q.931 does not define this octet)
30 First octet 4

The switch you are attached to is sending the Calling Party Subaddress with an encoding not defined in Q.931 but using the defined extension mechanism.  You should be able to alter the q931.c:receive_subaddr_helper() routine to check the ext bit in octet 3 and discard the extra octet 3 since Q.931 doesn't know how to interpret the extended octet.

> ARI: Error building JSON for PRI calls with Calling Party Subaddress Type NSAP
> ------------------------------------------------------------------------------
>
>                 Key: ASTERISK-27342
>                 URL: https://issues.asterisk.org/jira/browse/ASTERISK-27342
>             Project: Asterisk
>          Issue Type: Bug
>      Security Level: None
>          Components: Resources/res_stasis
>    Affects Versions: 13.11.2
>         Environment: Debian 8
>            Reporter: Marin Odrljin
>         Attachments: debug_log_subaddr-nok.txt
>
>
> There is a problem with starting Stasis application for incoming calls via PRI interface when there is Subaddress IE in Q.931 SETUP message.
> I'm not sure if the problem is in libpri, dahdi or asterisk source.
> I have attached a debug log 'debug_log_subaddr-nok.txt'.
> Please, check rows 19 and 20 where is 'Calling Party Subaddress'. If you check Q.931 specification [Q.931|https://www.itu.int/rec/dologin_pub.asp?lang=e&id=T-REC-Q.931-199805-I!!PDF-E&type=items] page 71-72 (4.5.11), you'll see how octet 4 should be decoded. Spec says if type of subaddress (octet 3) is NSAP ITU-T X.213 and ISO/IEC 8348, address shall be formatted as specified by octet 4 which contains Authority and Format Identifier (AFI). When you check octet 3 from my debug log [6d 0c 01 83 30 37 38 36 31 34 34 33 34 31] it is 01 what means it is NSAP type so octet 4 must be skipped in address information (or better to say treated differently), but unfortunately this is not a case in provided example. You can see that byte 83 is taken into subaddress information and result is decoded address 'ƒ0786144341'. I believe this is the root of errors that are happening later in code when building JSON in stasis_channels.c, json.c, res_stasis.c and other classes. The error message is quite logical 'Error building JSON from {s: ...} Invalid UTF-8 string'. Since JSON can't be created and it is needed for Stasis application, call never goes there (row 60-64 from debug log: 'res_stasis.c:159 stasis_start_to_json: Failed to pack JSON for StasisStart message') and it is disconnected after. 
> The same problem probably exists with SETUP IE 'Called Party Subaddress' (Q.931 spec 4.5.9, page 68-69) and also in CONNECT IE 'Connected Subaddress'.
> I have checked class [q931.c|https://github.com/asterisk/libpri/blob/master/q931.c] in libpri and saw that in the function 'receive_subaddr_helper' which is called by 'receive_calling_party_subaddr' and 2 others, all bytes from octet 4 are always copied into q931_subbaddres->data. It would be easy to skip octet 4 if type is NSAP, but I'm not sure that this is correct place to make changes because this one byte is then lost in structure and in the case of transmitting to other channel it will bring problems. Maybe this can be prevented if we add new field  'char afi' into 'q931_party_subaddress' struct and when type is NSAP to remove first byte from 'data' into it.
> If this is not the solution, then this byte must be removed when data is copied into asterisk objects when building json for Stasis, but I have no idea where is this and that's why not sure where the correction should be done, in libpri or somehere in asterisk.



--
This message was sent by Atlassian JIRA
(v6.2#6252)



More information about the asterisk-bugs mailing list