From: Florian Sauerteig Date: Tue, 6 Oct 2015 17:40:22 +0000 (+0200) Subject: chan_sip: Fix port parsing for IPv6 addresses in SIP Via headers. X-Git-Tag: 13.7.0-rc1~123 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=f939e2bd48598d721aa18af8182b7b6b91a9fe95;p=thirdparty%2Fasterisk.git chan_sip: Fix port parsing for IPv6 addresses in SIP Via headers. If a Via header containes an IPv6 address and a port number is ommitted, as it is the standard port, we now leave the port empty and to not set it to the value after the first colon of the IPv6 address. ASTERISK-25443 #close Change-Id: Ie3c2f05471cd006bf04ed15598589c09577b1e70 --- diff --git a/channels/sip/reqresp_parser.c b/channels/sip/reqresp_parser.c index e5c1ff2bca..31832a33ad 100644 --- a/channels/sip/reqresp_parser.c +++ b/channels/sip/reqresp_parser.c @@ -2420,7 +2420,7 @@ struct sip_via *parse_via(const char *header) /* store the port, we have to handle ipv6 addresses containing ':' * characters gracefully */ - if (((parm = strchr(v->sent_by, ']')) && *(++parm) == ':') || (parm = strchr(v->sent_by, ':'))) { + if (((parm = strchr(v->sent_by, ']')) && *(++parm) == ':') || (!(parm = strchr(v->sent_by, ']')) && (parm = strchr(v->sent_by, ':')))) { char *endptr; v->port = strtol(++parm, &endptr, 10);