Update of /usr/cvsroot/asterisk/channels
In directory mongoose.digium.com:/tmp/cvs-serv3710/channels

Modified Files:
        chan_sip.c 
Log Message:
Handle yet some SIP contact issue nuances and exceptions (bug #5289 with mods 
and rant)


Index: chan_sip.c
===================================================================
RCS file: /usr/cvsroot/asterisk/channels/chan_sip.c,v
retrieving revision 1.883
retrieving revision 1.884
diff -u -d -r1.883 -r1.884
--- chan_sip.c  12 Oct 2005 04:35:10 -0000      1.883
+++ chan_sip.c  12 Oct 2005 04:59:58 -0000      1.884
@@ -5279,7 +5279,7 @@
                        append_history(p, "RegistryInit", tmp);
                }
                /* Find address to hostname */
-               if (create_addr(p,r->hostname)) {
+               if (create_addr(p, r->hostname)) {
                        /* we have what we hope is a temporary network error,
                         * probably DNS.  We need to reschedule a registration 
try */
                        sip_destroy(p);
@@ -10764,12 +10764,14 @@
                        ignore=1;
                }
        
-               extract_uri(p, req);
                e = ast_skip_blanks(e);
                if (sscanf(e, "%d %n", &respid, &len) != 1) {
                        ast_log(LOG_WARNING, "Invalid response: '%s'\n", e);
                } else {
-                       handle_response(p, respid, e + len, req,ignore, seqno);
+                       /* More SIP ridiculousness, we have to ignore bogus 
contacts in 100 etc responses */
+                       if ((respid == 200) || ((respid >= 300) && (respid <= 
399)))
+                               extract_uri(p, req);
+                       handle_response(p, respid, e + len, req, ignore, seqno);
                }
                return 0;
        }

_______________________________________________
Asterisk-Cvs mailing list
[email protected]
http://lists.digium.com/mailman/listinfo/asterisk-cvs

Reply via email to