[Users] The usrloc table, Oracle, and Asterisk

Juan Carlos Castro y Castro jcastro at instant.com.br
Fri Dec 15 13:38:54 CET 2006


Any way I could catch the final OK message instead of the REGISTER 
message? Right now, I'm using the code below. Now I see that's not good 
because I get the Expires from the client which may be higher than the 
real Expires.

        if( method=="REGISTER" ) {
                if (!www_authorize("myrealm", "sip_conf")) {
                        www_challenge("myrealm", "0");
                        exit;
                };

                save("location");
                avp_db_query("UPDATE sipfriends SET ipaddr='$si', 
port='$sp', regseconds=$Ts+$hdr(expires), useragent='$ua' WHERE 
name='$au'");
                exit;
        };


Bogdan-Andrei Iancu escreveu:
> Hi Jerome,
>
> you are right - a server may change the expire advertised by the 
> client. If it is the case or not, it's a matter of configuration in 
> OpenSER - see the min_expires and max_expires in the registrar module.
>    http://www.openser.org/docs/modules/1.2.x/registrar.html
>
> if this params are not set, there is no risk of using the value 
> advertised by the client.
>
> regards,
> bogdan
>
> Jerome Martin wrote:
>
>> On Thu, 2006-12-14 at 17:32 -0200, Juan Carlos Castro y Castro wrote:
>>  
>>
>>> Forget I said that! There's $Ts + $hdr("Expires")! That'll teach me 
>>> to always RTFA before answering!
>>>   
>>
>> Well, you need to be carefull about $hdr("Expires"). This is NOT the
>> only way a UA can specify an expiration delay for a REGISTER request.
>>
>> If you take a look at the relevant parts of rfc3261
>> ( http://www.ietf.org/rfc/rfc3261.txt ), you'll see that using an
>> Expires header is only one way of specifying a desired expired duration
>> for the REGISTER. The other way is by using a Contact header parameter
>> (page 60 of the rfc) :
>>
>>  
>>
>>> 10.2.1.1 Setting the Expiration Interval of Contact Addresses
>>>
>>>   When a client sends a REGISTER request, it MAY suggest an expiration
>>>   interval that indicates how long the client would like the
>>>   registration to be valid.  (As described in Section 10.3, the
>>>   registrar selects the actual time interval based on its local
>>>   policy.)
>>>
>>>   There are two ways in which a client can suggest an expiration
>>>   interval for a binding: through an Expires header field or an
>>>   "expires" Contact header parameter.  The latter allows expiration
>>>   intervals to be suggested on a per-binding basis when more than one
>>>   binding is given in a single REGISTER request, whereas the former
>>>   suggests an expiration interval for all Contact header field values
>>>   that do not contain the "expires" parameter.
>>>   
>>
>> Also note that the expire parameter to a Contact header is totally 
>> case-unsensitive ( page 32 of the RFC) :
>>
>>
>>  
>>
>>>   When comparing header fields, field names are always case-
>>>   insensitive.  Unless otherwise stated in the definition of a
>>>   particular header field, field values, parameter names, and parameter
>>>   values are case-insensitive.  Tokens are always case-insensitive.
>>>   Unless specified otherwise, values expressed as quoted strings are
>>>   case-sensitive.  For example,
>>>
>>>      Contact: <sip:alice at atlanta.com>;expires=3600
>>>
>>>   is equivalent to
>>>
>>>      CONTACT: <sip:alice at atlanta.com>;ExPiReS=3600
>>>   
>>
>> A good example of a very popular SIP UA always using the Contact 
>> header parameter method is the Linksys PAP2 ATA. On the other hand, 
>> there are also
>> many popular ATAs that use the Expires header method, i.e. Audiocodes 
>> MP1XX ATAs. So unless you're in a very controlled environment and you 
>> don't
>> care at all to be generic and RFC3261-compliant, you must support 
>> both. But
>> be carefull, in my experience this almost always bites you back one 
>> day or the other.
>>
>> Hope this helps,
>> Best Regards,
>>
>> Jérôme Martin
>>
>>
>>
>>
>>
>>  
>>
>
>





More information about the Users mailing list