diff options
author | bbryant <bbryant@f38db490-d61c-443f-a65b-d21fe96a405b> | 2008-07-08 21:00:01 +0000 |
---|---|---|
committer | bbryant <bbryant@f38db490-d61c-443f-a65b-d21fe96a405b> | 2008-07-08 21:00:01 +0000 |
commit | 58438598f6da07d9d993bc8e7577f7b9c4ef8cea (patch) | |
tree | 8e9a693e7fa17da065334a16d148af63f7faaf5b /main/dnsmgr.c | |
parent | 8b49aad36466ab8bf0abdf16273ee6cd769bda43 (diff) |
Fix a bug in SRV lookups where dnsmgr would discard everything but the
first SRV result from DNS before processing weights and priorities and
dns_parse_answer wouldn't report that there were no records in DNS
unless a failure occured. Also fixed a bug where dnsmgr_refresh would
report that a entry was being changed when ast_gethostbyname had failed.
git-svn-id: http://svn.digium.com/svn/asterisk/trunk@129156 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'main/dnsmgr.c')
-rw-r--r-- | main/dnsmgr.c | 3 |
1 files changed, 1 insertions, 2 deletions
diff --git a/main/dnsmgr.c b/main/dnsmgr.c index cae20f4b7..727d8b5fc 100644 --- a/main/dnsmgr.c +++ b/main/dnsmgr.c @@ -164,8 +164,7 @@ static int dnsmgr_refresh(struct ast_dnsmgr_entry *entry, int verbose) if (verbose) ast_verb(3, "refreshing '%s'\n", entry->name); - ast_get_ip_or_srv(&tmp, entry->name, entry->service); - if (inaddrcmp(&tmp, &entry->last)) { + if (!ast_get_ip_or_srv(&tmp, entry->name, entry->service) && inaddrcmp(&tmp, &entry->last)) { ast_copy_string(iabuf, ast_inet_ntoa(entry->last.sin_addr), sizeof(iabuf)); ast_copy_string(iabuf2, ast_inet_ntoa(tmp.sin_addr), sizeof(iabuf2)); ast_log(LOG_NOTICE, "dnssrv: host '%s' changed from %s:%d to %s:%d\n", |