[asterisk-commits] oej: branch oej/gin-register-bnc-1.8 r426076 - in /team/oej/gin-register-bnc-...

SVN commits to the Asterisk project asterisk-commits at lists.digium.com
Tue Oct 21 04:29:08 CDT 2014


Author: oej
Date: Tue Oct 21 04:28:55 2014
New Revision: 426076

URL: http://svnview.digium.com/svn/asterisk?view=rev&rev=426076
Log:
Coding in the deep, blindly

Modified:
    team/oej/gin-register-bnc-1.8/channels/chan_sip.c
    team/oej/gin-register-bnc-1.8/channels/sip/config_parser.c
    team/oej/gin-register-bnc-1.8/channels/sip/include/sip.h

Modified: team/oej/gin-register-bnc-1.8/channels/chan_sip.c
URL: http://svnview.digium.com/svn/asterisk/team/oej/gin-register-bnc-1.8/channels/chan_sip.c?view=diff&rev=426076&r1=426075&r2=426076
==============================================================================
--- team/oej/gin-register-bnc-1.8/channels/chan_sip.c (original)
+++ team/oej/gin-register-bnc-1.8/channels/chan_sip.c Tue Oct 21 04:28:55 2014
@@ -1532,6 +1532,7 @@
 static void set_destination(struct sip_pvt *p, char *uri);
 static void append_date(struct sip_request *req);
 static void build_contact(struct sip_pvt *p);
+static void build_contact_param(struct sip_pvt *p, const char *param);
 
 /*------Request handling functions */
 static int handle_incoming(struct sip_pvt *p, struct sip_request *req, struct ast_sockaddr *addr, int *recount, int *nounlock);
@@ -12328,16 +12329,33 @@
 /*! \brief Build contact header - the contact header we send out */
 static void build_contact(struct sip_pvt *p)
 {
+	build_contact_param(p, NULL);
+}
+
+/*! \brief Build contact header and add contact URI parameter.
+	URI parameter needs to start with ";" and be separated by ";"'s */
+static void build_contact_param(struct sip_pvt *p, const char *param)
+{
 	char tmp[SIPBUFSIZE];
+	char params[SIPBUFSIZE];
 	char *user = ast_uri_encode(p->exten, tmp, sizeof(tmp), 0);
 
-	if (p->socket.type == SIP_TRANSPORT_UDP) {
-		ast_string_field_build(p, our_contact, "<sip:%s%s%s>", user,
-			ast_strlen_zero(user) ? "" : "@", ast_sockaddr_stringify_remote(&p->ourip));
+	params[0] = '\0';
+	if(ast_strlen_zero(param)) {
+		if (p->socket.type != SIP_TRANSPORT_UDP) {
+			snprintf(params, sizeof(params), ";transport=%s", get_transport(p->socket.type));
+		}
 	} else {
-		ast_string_field_build(p, our_contact, "<sip:%s%s%s;transport=%s>", user,
+		if (p->socket.type != SIP_TRANSPORT_UDP) {
+			snprintf(params, sizeof(params), ";transport=%s%s", get_transport(p->socket.type), param);
+		} else {
+			snprintf(params, sizeof(params), ";%s", param);
+		}
+	}
+
+	ast_string_field_build(p, our_contact, "<sip:%s%s%s%s>", user,
 			ast_strlen_zero(user) ? "" : "@", ast_sockaddr_stringify_remote(&p->ourip),
-			get_transport(p->socket.type));
+			params);
 	}
 }
 
@@ -13830,7 +13848,9 @@
 		}
 		/* Save extension in packet */
 		if (!ast_strlen_zero(r->callback)) {
-			ast_string_field_set(p, exten, r->callback);
+			if (!r->bnc) {
+				ast_string_field_set(p, exten, r->callback);
+			}
 		}
 
 		/* Set transport and port so the correct contact is built */
@@ -13846,7 +13866,11 @@
 		  internal network so we can register through nat
 		 */
 		ast_sip_ouraddrfor(&p->sa, &p->ourip, p);
-		build_contact(p);
+		if (r->bnc) {
+			build_contact_param(p, ";bnc");
+		} else {
+			build_contact(p);
+		}
 	}
 
 	/* set up a timeout */
@@ -13927,6 +13951,13 @@
 	snprintf(tmp, sizeof(tmp), "%d", r->expiry);
 	add_header(&req, "Expires", tmp);
 	add_header(&req, "Contact", p->our_contact);
+
+	if (r->bnc) {
+		/* RFC 6140 headers required */
+		add_header(&req, "Supported", "path");
+		add_header(&req, "Require", "gin");
+		add_header(&req, "Proxy-Require", "gin");
+	}
 
 	initialize_initreq(p, &req);
 	if (sip_debug_test_pvt(p)) {

Modified: team/oej/gin-register-bnc-1.8/channels/sip/config_parser.c
URL: http://svnview.digium.com/svn/asterisk/team/oej/gin-register-bnc-1.8/channels/sip/config_parser.c?view=diff&rev=426076&r1=426075&r2=426076
==============================================================================
--- team/oej/gin-register-bnc-1.8/channels/sip/config_parser.c (original)
+++ team/oej/gin-register-bnc-1.8/channels/sip/config_parser.c Tue Oct 21 04:28:55 2014
@@ -250,6 +250,10 @@
 			portnum = STANDARD_SIP_PORT;
 		}
 	}
+	reg->bnc = FALSE;
+	if (!strncasecmp(host2.extension, "-bnc-", 5)) {
+		reg->bnc = TRUE;
+	}
 
 	/* copy into sip_registry object */
 	ast_string_field_set(reg, callback, ast_strip_quoted(S_OR(host2.extension, "s"), "\"", "\""));

Modified: team/oej/gin-register-bnc-1.8/channels/sip/include/sip.h
URL: http://svnview.digium.com/svn/asterisk/team/oej/gin-register-bnc-1.8/channels/sip/include/sip.h?view=diff&rev=426076&r1=426075&r2=426076
==============================================================================
--- team/oej/gin-register-bnc-1.8/channels/sip/include/sip.h (original)
+++ team/oej/gin-register-bnc-1.8/channels/sip/include/sip.h Tue Oct 21 04:28:55 2014
@@ -1326,6 +1326,7 @@
 	int regattempts;        /*!< Number of attempts (since the last success) */
 	int timeout;            /*!< sched id of sip_reg_timeout */
 	int refresh;            /*!< How often to refresh */
+	int bnc;		/*!< Bulk number contact (RFC 6140) */
 	struct sip_pvt *call;   /*!< create a sip_pvt structure for each outbound "registration dialog" in progress */
 	enum sipregistrystate regstate; /*!< Registration state (see above) */
 	struct timeval regtime;         /*!< Last successful registration time */




More information about the asterisk-commits mailing list