aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDaniel Stenberg <daniel@haxx.se>2008-07-03 11:32:35 +0000
committerDaniel Stenberg <daniel@haxx.se>2008-07-03 11:32:35 +0000
commite3b5673e9895fa53525eb3b3620e3ececf0761ff (patch)
tree23da0f25485ab62b19a202b080499c792e6b5528
parent82412f218fe6809288c718c5b43b9675eb2856f5 (diff)
- Phil Blundell: If you ask ares_gethostbyname() to do an AF_INET6 lookup and
the target host has only A records, it automatically falls back to an AF_INET lookup and gives you the A results. However, if the target host has a CNAME record, this behaviour is defeated since the original query does return some data even though ares_parse_aaa_reply() doesn't consider it relevant. Here's a small patch to make it behave the same with and without the CNAME.
-rw-r--r--ares/CHANGES9
-rw-r--r--ares/ares_gethostbyname.c9
2 files changed, 18 insertions, 0 deletions
diff --git a/ares/CHANGES b/ares/CHANGES
index ffe530d52..deed11db3 100644
--- a/ares/CHANGES
+++ b/ares/CHANGES
@@ -1,5 +1,14 @@
Changelog for the c-ares project
+* Jul 3 2008 (Daniel Stenberg)
+- Phil Blundell: If you ask ares_gethostbyname() to do an AF_INET6 lookup and
+ the target host has only A records, it automatically falls back to an
+ AF_INET lookup and gives you the A results. However, if the target host has
+ a CNAME record, this behaviour is defeated since the original query does
+ return some data even though ares_parse_aaa_reply() doesn't consider it
+ relevant. Here's a small patch to make it behave the same with and without
+ the CNAME.
+
* Jul 2 2008 (Yang Tse)
- Fallback to gettimeofday when monotonic clock is unavailable at run-time.
diff --git a/ares/ares_gethostbyname.c b/ares/ares_gethostbyname.c
index d737b41f2..1e7e1585e 100644
--- a/ares/ares_gethostbyname.c
+++ b/ares/ares_gethostbyname.c
@@ -176,6 +176,15 @@ static void host_callback(void *arg, int status, int timeouts,
else if (hquery->family == AF_INET6)
{
status = ares_parse_aaaa_reply(abuf, alen, &host, NULL, NULL);
+ if (status == ARES_ENODATA)
+ {
+ /* The query returned something (e.g. CNAME) but there were no
+ AAAA records. Try looking up A instead. */
+ hquery->family = AF_INET;
+ ares_search(hquery->channel, hquery->name, C_IN, T_A, host_callback,
+ hquery);
+ return;
+ }
if (host && channel->nsort)
sort6_addresses(host, channel->sortlist, channel->nsort);
}