aboutsummaryrefslogtreecommitdiffstats
path: root/channels
diff options
context:
space:
mode:
authorjrose <jrose@f38db490-d61c-443f-a65b-d21fe96a405b>2011-05-23 14:40:59 +0000
committerjrose <jrose@f38db490-d61c-443f-a65b-d21fe96a405b>2011-05-23 14:40:59 +0000
commit90da28ff05e5ca7a2034d29b162f9d4b2e8976e3 (patch)
treee352d8b63821f8541b6f6b9c2e86e7c4e53dc16a /channels
parent695a84cd4855c91000bd711d74a99b5c9f9c1436 (diff)
Merged revisions 320504 via svnmerge from
https://origsvn.digium.com/svn/asterisk/branches/1.8 ........ r320504 | jrose | 2011-05-23 09:33:20 -0500 (Mon, 23 May 2011) | 10 lines Fixes segfault occuring in chan_sip.c at __set_address_from_contact Checks to see if domain contains anything before sending it off to ast_sockaddr_resolve which is where the segfault was occuring due to null str. (closes issue #18857) Reported by: sybasesql Review: https://reviewboard.asterisk.org/r/1225/ ........ git-svn-id: http://svn.digium.com/svn/asterisk/trunk@320505 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'channels')
-rw-r--r--channels/chan_sip.c7
1 files changed, 7 insertions, 0 deletions
diff --git a/channels/chan_sip.c b/channels/chan_sip.c
index 82b27acfa..0c515a954 100644
--- a/channels/chan_sip.c
+++ b/channels/chan_sip.c
@@ -13589,6 +13589,13 @@ static int __set_address_from_contact(const char *fullcontact, struct ast_sockad
assume that the domain part is a host name and only look for an A/AAAA record in DNS.
*/
+ /* If we took in an invalid URI, domain may not have been initialized */
+ /* ast_sockaddr_resolve requires an initialized domain string. */
+ if (ast_strlen_zero(domain)) {
+ ast_log(LOG_WARNING, "Invalid URI: parse_uri failed to acquire domain\n");
+ return -1;
+ }
+
if (ast_sockaddr_resolve_first(addr, domain, 0)) {
ast_log(LOG_WARNING, "Invalid host name in Contact: (can't "
"resolve in DNS) : '%s'\n", domain);