[svn-commits] mmichelson: branch group/issue8824 r143533 - /team/group/issue8824/channels/

SVN commits to the Digium repositories svn-commits at lists.digium.com
Thu Sep 18 16:54:28 CDT 2008


Author: mmichelson
Date: Thu Sep 18 16:54:27 2008
New Revision: 143533

URL: http://svn.digium.com/view/asterisk?view=rev&rev=143533
Log:
All redirecting information except the reason is updated
properly now when appropriate.

I will work on reason stuff next and should have it done
soonly.


Modified:
    team/group/issue8824/channels/chan_sip.c

Modified: team/group/issue8824/channels/chan_sip.c
URL: http://svn.digium.com/view/asterisk/team/group/issue8824/channels/chan_sip.c?view=diff&rev=143533&r1=143532&r2=143533
==============================================================================
--- team/group/issue8824/channels/chan_sip.c (original)
+++ team/group/issue8824/channels/chan_sip.c Thu Sep 18 16:54:27 2008
@@ -15204,8 +15204,51 @@
 };
 
 /*XXX TODO Write this*/
-static int read_ruri_parts(struct sip_pvt *p, struct sip_request *req, char **name, char **number)
-{
+static int read_to_parts(struct sip_pvt *p, struct sip_request *req, char **name, char **number)
+{
+
+	char to_header[256];
+	char *to_name = NULL;
+	char *to_number = NULL;
+	char *separator;
+
+	ast_copy_string(to_header, get_header(req, "To"), sizeof(to_header));
+
+	/* Let's get that number first! */
+	to_number = get_in_brackets(to_header);
+
+	if (!strncasecmp(to_number, "sip:", 4)) {
+		to_number += 4;
+	} else if (!strncasecmp(to_number, "sips:", 5)) {
+		to_number += 5;
+	} else {
+		ast_log(LOG_WARNING, "Not a SIP URI? (%s)!\n", to_number);
+		return -1;
+	}
+
+	/* Remove the host and such since we just want the number */
+	if ((separator = strchr(to_number, '@'))) {
+		*separator = '\0';
+	}
+
+	/* We have the number. Let's get the name now. */
+
+	if (*to_header == '\"') {
+		to_name = to_header + 1;
+		if (!(separator = (char *)find_closing_quote(to_name, NULL))) {
+			ast_log(LOG_NOTICE, "No closing quote in name section of To: header (%s)\n", to_header);
+			return -1;
+		}
+		*separator = '\0';
+	}
+
+	if (number) {
+		*number = ast_strdup(to_number);
+	}
+	if (name && !ast_strlen_zero(to_name)) {
+		*name = ast_strdup(to_name);
+	}
+
 	return 0;
 }
 
@@ -15224,7 +15267,7 @@
 	res = get_rdnis(p, req, &redirecting_from_name, &redirecting_from_number);
 	if (res == -1) {
 		if (is_response) {
-			read_ruri_parts(p, req, &redirecting_from_name, &redirecting_from_number);
+			read_to_parts(p, req, &redirecting_from_name, &redirecting_from_number);
 		} else {
 			return;
 		}
@@ -15237,7 +15280,7 @@
 	if (is_response) {
 		parse_moved_contact(p, req, &redirecting_to_name, &redirecting_to_number);
 	} else {
-		read_ruri_parts(p, req, &redirecting_to_name, &redirecting_to_number);
+		read_to_parts(p, req, &redirecting_to_name, &redirecting_to_number);
 	}
 
 	/* This check could probably moved up higher so we don't do any unnecessary
@@ -15254,24 +15297,28 @@
 		if (p->owner->cid.cid_rdnis) {
 			ast_free(p->owner->cid.cid_rdnis);
 		}
-		p->owner->cid.cid_rdnis = ast_strdup(redirecting_from_number);
+		ast_debug(3, "Got redirecting from number %s\n", redirecting_from_number);
+		p->owner->cid.cid_rdnis = redirecting_from_number;
 	}
 	if (!ast_strlen_zero(redirecting_from_name)) {
 		if (p->owner->redirecting.from.name) {
 			ast_free(p->owner->redirecting.from.name);
 		}
-		p->owner->redirecting.from.name = ast_strdup(redirecting_from_name);
+		ast_debug(3, LOG_NOTICE, "Got redirecting from name %s\n", redirecting_from_name);
+		p->owner->redirecting.from.name = redirecting_from_name;
 	}
 	if (!ast_strlen_zero(redirecting_to_number)) {
 		if (p->owner->redirecting.to.number) {
 			ast_free(p->owner->redirecting.to.number);
 		}
+		ast_debug(3, LOG_NOTICE, "Got redirecting to number %s\n", redirecting_to_number);
 		p->owner->redirecting.to.number = redirecting_to_number;
 	}
 	if (!ast_strlen_zero(redirecting_to_name)) {
 		if (p->owner->redirecting.to.name) {
 			ast_free(p->owner->redirecting.to.name);
 		}
+		ast_debug(3, LOG_NOTICE, "Got redirecting to name %s\n", redirecting_from_number);
 		p->owner->redirecting.to.name = redirecting_to_name;
 	}
 }
@@ -15367,9 +15414,10 @@
 
 	if (*contact == '\"') {
 		contact_name = contact + 1;
-		if ((separator = strchr(contact_name, '\"'))) {
-			*separator = '\0';
-		}
+		if (!(separator = (char *)find_closing_quote(contact_name, NULL))) {
+			ast_log(LOG_NOTICE, "No closing quote on name in Contact header? %s\n", contact);
+		}
+		*separator = '\0';
 	}
 
 	if (name && !ast_strlen_zero(contact_name)) {




More information about the svn-commits mailing list