[asterisk-bugs] [JIRA] (ASTERISK-23267) URI parameters passed in 200 OK response to register prevent Asterisk from matching contact field and updating expire time.
Adam Dugan (JIRA)
noreply at issues.asterisk.org
Wed Feb 12 11:31:03 CST 2014
[ https://issues.asterisk.org/jira/browse/ASTERISK-23267?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]
Adam Dugan updated ASTERISK-23267:
----------------------------------
Environment: AstLinux 1.1.0 (was: AsteriskNOW 1.1.0)
> URI parameters passed in 200 OK response to register prevent Asterisk from matching contact field and updating expire time.
> ---------------------------------------------------------------------------------------------------------------------------
>
> Key: ASTERISK-23267
> URL: https://issues.asterisk.org/jira/browse/ASTERISK-23267
> Project: Asterisk
> Issue Type: Bug
> Security Level: None
> Affects Versions: 1.8.20.1
> Environment: AstLinux 1.1.0
> Reporter: Adam Dugan
> Severity: Minor
>
> When Asterisk receives Contact header expires parameter it will update the expiry for the registration only if it exactly matches the contact used in the registration request.
> Asterisk sends register request with:
> {noformat}
> REGISTER
> From: <sip:2125551000 at 192.168.1.1:5060>;tag=xxxxxxxxxx
> {noformat}
> This 200 OK will cause Asterisk to update expiration to 125 seconds.
> {noformat}
> 200 OK
> Contact: <sip:2125551000 at 192.168.1.1:5060>;expires=125
> {noformat}
> This 200 OK will cause Asterisk to ignore the contact header and use it's default expiry instead of the one specified:
> {noformat}
> Contact: <sip:2125551000 at 192.168.1.1:5060;ep=192.168.1.1;fw=74.125.235.232>;expires=125
> {noformat}
> This issue has been discussed before and closed, but in the previous instance the URI in the contact header was not formatted correctly (see: ASTERISK-14870 ).
> Per the RFC:
> {quote}
> RFC 3261 10.3 Processing REGISTER Requests
> 8. The registrar returns a 200 (OK) response. The response MUST
> contain Contact header field values enumerating all current
> bindings. Each Contact value MUST feature an "expires"
> parameter indicating its expiration interval chosen by the
> registrar. The response SHOULD include a Date header field.
> RFC 3261 19.1.4 URI Comparison
> URI uri-parameter components are compared as follows:
> - Any uri-parameter appearing in both URIs must match.
> - A user, ttl, or method uri-parameter appearing in only one
> URI never matches, even if it contains the default value.
> - A URI that includes an maddr parameter will not match a URI
> that contains no maddr parameter.
> - All other uri-parameters appearing in only one URI are
> ignored when comparing the URIs.
> {quote}
> I've been pouring over the RFC trying to figure out what is correct. Sections I've read could interpret to mean the Contact header returned in the 200 OK must exactly match that used in the register request, and that the URI parameters might be ok.
> I'm currently using a VoIP provider that is returning a Contact header in the 200 OK with endpoint and firewall (ep & fw) URI parameters. This is causing Asterisk not to respect the expires time and subsequently causing my registration to timeout on the carrier side before Asterisk re-registers. As the carrier requests an expiry less then the minimum allowed upon connect there is no way to successfully stay connected editing the Asterisk configuration files alone.
> The Oracle Session Border Controller seems to have the behavior of adding the fw firewall and ep endpoint URI parameters to the Contact field of SIP packets. See Using Private IPv4 Addresses, Page 282: http://docs.oracle.com/cd/E50377_01/doc/sbc_sc610_acliconfiguration.pdf
> Looking at the code it does appear there is a string compare. I haven't traced back to the parse yet to see if it's stripping out the URI parameters. Based on the behavior I've experienced it isn't.
> http://svnview.digium.com/svn/asterisk/branches/1.8/channels/chan_sip.c?revision=406170&view=markup
> {code}
> 21558 if (!ast_strlen_zero(get_header(req, "Contact"))) {
> 21559 const char *contact = NULL;
> 21560 const char *tmptmp = NULL;
> 21561 int start = 0;
> 21562 for(;;) {
> 21563 contact = __get_header(req, "Contact", &start);
> 21564 /* this loop ensures we get a contact header about our register request */
> 21565 if(!ast_strlen_zero(contact)) {
> 21566 if( (tmptmp=strstr(contact, p->our_contact))) {
> 21567 contact=tmptmp;
> 21568 break;
> 21569 }
> 21570 } else
> 21571 break;
> 21572 }
> 21573 tmptmp = strcasestr(contact, "expires=");
> 21574 if (tmptmp) {
> 21575 if (sscanf(tmptmp + 8, "%30d", &expires) != 1) {
> 21576 expires = 0;
> 21577 }
> 21578 }
> 21579
> 21580 }
> 21581 if (!expires)
> 21582 expires=atoi(get_header(req, "expires"));
> 21583 if (!expires)
> 21584 expires=default_expiry;
> {code}
> With debugging on:
> {noformat}
> REGISTER:
> [2014-02-07 21:45:18] DEBUG[1663]: chan_sip.c:8914 parse_request: Header 10 [ 40]: Contact: <sip:2125551000 at 191.168.1.1:5060>
> 200 OK:
> [2014-02-07 21:45:18] DEBUG[1663]: chan_sip.c:8914 parse_request: Header 6 [ 80]: Contact: <sip:2125551000 at 192.168.1.1:5060;ep=192.168.1.1;fw=74.125.235.232>;expires=155
> {noformat}
> I've tried to find someone in the forums & IRC channels to provide opinions on whether Asterisk or Oracle is following the standard and which one isn't. As Asterisk is intended to be interoperable with other SIP products, and Oracle is a major manufacturer there probably should be a solution.
--
This message is automatically generated by JIRA.
If you think it was sent incorrectly, please contact your JIRA administrators: https://issues.asterisk.org/jira/secure/ContactAdministrators!default.jspa
For more information on JIRA, see: http://www.atlassian.com/software/jira
More information about the asterisk-bugs
mailing list