[svn-commits] russell: branch bbryant/sip-tcptls r73764 - /team/bbryant/sip-tcptls/channels/

SVN commits to the Digium repositories svn-commits at lists.digium.com
Fri Jul 6 15:54:28 CDT 2007


Author: russell
Date: Fri Jul  6 15:54:27 2007
New Revision: 73764

URL: http://svn.digium.com/view/asterisk?view=rev&rev=73764
Log:
little code cleanups

Modified:
    team/bbryant/sip-tcptls/channels/chan_sip.c

Modified: team/bbryant/sip-tcptls/channels/chan_sip.c
URL: http://svn.digium.com/view/asterisk/team/bbryant/sip-tcptls/channels/chan_sip.c?view=diff&rev=73764&r1=73763&r2=73764
==============================================================================
--- team/bbryant/sip-tcptls/channels/chan_sip.c (original)
+++ team/bbryant/sip-tcptls/channels/chan_sip.c Fri Jul  6 15:54:27 2007
@@ -1224,7 +1224,7 @@
 		AST_STRING_FIELD(callback);	/*!< Contact extension */
 		AST_STRING_FIELD(random);
 	);
-	int transport;
+	enum sip_transport transport;
 	int portno;			/*!<  Optional port override */
 	int expire;			/*!< Sched ID of expiration */
 	int expiry;			/*!< Value to use for the Expires header */
@@ -2624,9 +2624,7 @@
 			ast_log(LOG_WARNING, "No closing bracket found in '%s'\n", tmp);
 		}
 	}
-	/* TODO Fix this to something cleaner  */
-	if (!strncmp(tmp, "sips:", 5))
-		sprintf(tmp, "sip%s", tmp+4);
+	
 	return tmp;
 }
 
@@ -5044,8 +5042,9 @@
 {
 	struct sip_registry *reg;
 	int portnum = 0;
-	int transport = SIP_TRANSPORT_UDP;
-	char username[256] = "";
+	enum sip_transport transport = SIP_TRANSPORT_UDP;
+	char buf[256] = "";
+	char *username = NULL;
 	char *hostname=NULL, *secret=NULL, *authuser=NULL;
 	char *porta=NULL;
 	char *callback=NULL;
@@ -5053,33 +5052,29 @@
 
 	if (!value)
 		return -1;
-	ast_copy_string(username, value, sizeof(username));
-
-	trans = strstr(username, "://");
-
-	if (trans) {
-		*trans = '\0';
-
-		if (trans - username == 3 && 
-			(!strncasecmp(username, "udp", 3) ||
-		  	 !strncasecmp(username, "tcp", 3) ||
-		   	 !strncasecmp(username, "tls", 3))) {
-			switch(username[1] + ((username[1] < 97) ? 32 : 0)) { // Ensure lowercase
-				case 'c':
-					transport = SIP_TRANSPORT_TCP;
-					break;
-				case 'l':
-					transport = SIP_TRANSPORT_TLS;
-					break;
-			}
-		} else {
-		    ast_log(LOG_WARNING, "Invalid transport type '%s' given at line %d\n", username, lineno);
-		}
-
-		ast_copy_string(username, trans + 3, sizeof(username));
-	}
-
-	ast_log(LOG_DEBUG, "Transport type is '%d' for register URI '%s'\n", transport, username);
+
+	ast_copy_string(buf, value, sizeof(buf));
+
+	username = strstr(buf, "://");
+
+	if (username) {
+		*username = '\0';
+		username += 3;
+
+		trans = buf;
+
+		if (!strcasecmp(trans, "udp"))
+			transport = SIP_TRANSPORT_UDP;
+		else if (!strcasecmp(trans, "tcp"))
+			transport = SIP_TRANSPORT_TCP;
+		else if (!strcasecmp(trans, "tls"))
+			transport = SIP_TRANSPORT_TLS;
+		else
+			ast_log(LOG_WARNING, "'%s' is not a valid transport value for registration '%s' at line '%d'\n", trans, value, lineno);
+	} else {
+		username = buf;
+		ast_log(LOG_DEBUG, "no trans\n");
+	}
 
 	/* First split around the last '@' then parse the two components. */
 	hostname = strrchr(username, '@'); /* allow @ in the first part */
@@ -17495,8 +17490,7 @@
 	memset(&global_outboundproxy, 0, sizeof(struct sip_proxy));
 	global_outboundproxy.ip.sin_port = htons(STANDARD_SIP_PORT);
 	global_outboundproxy.ip.sin_family = AF_INET;	/* Type of address: IPv4 */
-	ourport = 
-	ourport_tcp = STANDARD_SIP_PORT;
+	ourport = ourport_tcp = STANDARD_SIP_PORT;
 	ourport_tls = STANDARD_TLS_PORT;
 	global_srvlookup = DEFAULT_SRVLOOKUP;
 	global_tos_sip = DEFAULT_TOS_SIP;




More information about the svn-commits mailing list