[asterisk-commits] oej: branch oej/siptransdirection r45285 - /team/oej/siptransdirection/channels/

asterisk-commits at lists.digium.com asterisk-commits at lists.digium.com
Mon Oct 16 13:26:16 MST 2006


Author: oej
Date: Mon Oct 16 15:26:16 2006
New Revision: 45285

URL: http://svn.digium.com/view/asterisk?rev=45285&view=rev
Log:
Trying to add some sense of direction in a transaction.

If we have an OUTBOUND call, we still may get a RE-INVITE which
creates an inbound transaction.

On an INBOUND call, we might send a RE-INVITE, which creates
an outbound transaction.

This outbound/inbound stuff confuses the CANCEL and the ACK
and mixes some TO/FROM headers and tags.

This patch is *not* tested yet.

Modified:
    team/oej/siptransdirection/channels/chan_sip.c

Modified: team/oej/siptransdirection/channels/chan_sip.c
URL: http://svn.digium.com/view/asterisk/team/oej/siptransdirection/channels/chan_sip.c?rev=45285&r1=45284&r2=45285&view=diff
==============================================================================
--- team/oej/siptransdirection/channels/chan_sip.c (original)
+++ team/oej/siptransdirection/channels/chan_sip.c Mon Oct 16 15:26:16 2006
@@ -449,7 +449,6 @@
 #define INC_CALL_LIMIT	1
 
 static struct ast_codec_pref prefs;
-
 
 /*! \brief sip_request: The data grabbed from the UDP socket */
 struct sip_request {
@@ -4142,6 +4141,7 @@
 	char *c, *n;
 	char *ot, *of;
 	int is_strict = 0;	/* Strict routing flag */
+	int is_outbound = ast_test_flag(p, SIP_OUTGOING);	/* Incoming session */
 
 	memset(req, 0, sizeof(struct sip_request));
 	
@@ -4199,14 +4199,24 @@
 	ot = get_header(orig, "To");
 	of = get_header(orig, "From");
 
+	/* Let's try to figure out where this transaction is heading */
+	/* If we're sending an ACK, we did send the INVITE, regardless
+	   of the direction of the call  */
+	/* If we are sending an INVITE, it's outbound again (could be a re-invite) */
+	if (sipmethod == SIP_ACK || sipmethod == SIP_INVITE)
+		is_outbound = 1;
+
+	/* In other cases, let's stick with the direction of the dialog */
+
 	/* Add tag *unless* this is a CANCEL, in which case we need to send it exactly
 	   as our original request, including tag (or presumably lack thereof) */
+	
 	if (!strcasestr(ot, "tag=") && sipmethod != SIP_CANCEL) {
 		/* Add the proper tag if we don't have it already.  If they have specified
 		   their tag, use it.  Otherwise, use our own tag */
-		if (ast_test_flag(p, SIP_OUTGOING) && !ast_strlen_zero(p->theirtag))
+		if (is_outbound && !ast_strlen_zero(p->theirtag))
 			snprintf(newto, sizeof(newto), "%s;tag=%s", ot, p->theirtag);
-		else if (!ast_test_flag(p, SIP_OUTGOING))
+		else if (is_outbound)
 			snprintf(newto, sizeof(newto), "%s;tag=%s", ot, p->tag);
 		else
 			snprintf(newto, sizeof(newto), "%s", ot);
@@ -4214,13 +4224,13 @@
 	}
 
 	if (ast_test_flag(p, SIP_OUTGOING)) {
-		add_header(req, "From", of);
-		add_header(req, "To", ot);
-	} else {
-		add_header(req, "From", ot);
-		add_header(req, "To", of);
-	}
-	add_header(req, "Contact", p->our_contact);
+		add_header(req, "From", is_outbound ? of : ot);
+		add_header(req, "To",  is_outbound ? ot : of);
+	}
+
+	/* Don't add Contact for BYE and Cancel requests */
+	if (sipmethod != SIP_BYE && sipmethod != SIP_CANCEL)
+		add_header(req, "Contact", p->our_contact);
 	copy_header(req, orig, "Call-ID");
 	add_header(req, "CSeq", tmp);
 



More information about the asterisk-commits mailing list