summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorStuart Henderson <sthen@cvs.openbsd.org>2015-08-17 10:48:11 +0000
committerStuart Henderson <sthen@cvs.openbsd.org>2015-08-17 10:48:11 +0000
commitc5ff96b560b9c7c91e84d74c366d5a7e11ce50ef (patch)
tree8ed51939b0575cb4168f12fd0b23fe7e94e88e8a
parent87a64952a2217bc2eb8b1ad0e7f229b96d9d5dfa (diff)
Fix whois server detection for new TLDs using whois.nic.<domain> where
<domain> has an old TLD as a substring. Specifically, fixes .network lookups. While there, simplify a strlcpy+strlcat to snprintf. ok millert@ phessler@
-rw-r--r--usr.bin/whois/whois.c25
1 files changed, 12 insertions, 13 deletions
diff --git a/usr.bin/whois/whois.c b/usr.bin/whois/whois.c
index f085f568791..18b9a8c8c07 100644
--- a/usr.bin/whois/whois.c
+++ b/usr.bin/whois/whois.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: whois.c,v 1.47 2015/04/09 19:29:53 sthen Exp $ */
+/* $OpenBSD: whois.c,v 1.48 2015/08/17 10:48:10 sthen Exp $ */
/*
* Copyright (c) 1980, 1993
@@ -310,22 +310,21 @@ choose_server(const char *name, const char *country)
* Post-2003 ("new") gTLDs are all supposed to have "whois.nic.domain"
* (per registry agreement), some older gTLDs also support this...
*/
- strlcpy(server, "whois.nic.", len);
- strlcat(server, qhead, len);
+ snprintf(server, len, "whois.nic.%s", qhead);
/* most ccTLDs don't do this, but QNICHOST/whois-servers mostly works */
if ((strlen(qhead) == 2 ||
/* and is required for most of the <=2003 TLDs/gTLDs */
- strncasecmp(qhead, "org", 3) == 0 ||
- strncasecmp(qhead, "com", 3) == 0 ||
- strncasecmp(qhead, "net", 3) == 0 ||
- strncasecmp(qhead, "cat", 3) == 0 ||
- strncasecmp(qhead, "pro", 3) == 0 ||
- strncasecmp(qhead, "info", 4) == 0 ||
- strncasecmp(qhead, "aero", 4) == 0 ||
- strncasecmp(qhead, "jobs", 4) == 0 ||
- strncasecmp(qhead, "mobi", 4) == 0 ||
- strncasecmp(qhead, "museum", 6) == 0 ||
+ strcasecmp(qhead, "org") == 0 ||
+ strcasecmp(qhead, "com") == 0 ||
+ strcasecmp(qhead, "net") == 0 ||
+ strcasecmp(qhead, "cat") == 0 ||
+ strcasecmp(qhead, "pro") == 0 ||
+ strcasecmp(qhead, "info") == 0 ||
+ strcasecmp(qhead, "aero") == 0 ||
+ strcasecmp(qhead, "jobs") == 0 ||
+ strcasecmp(qhead, "mobi") == 0 ||
+ strcasecmp(qhead, "museum") == 0 ||
/* for others, if whois.nic.TLD doesn't exist, try whois-servers */
getaddrinfo(server, NULL, &hints, &res) != 0)) {
strlcpy(server, qhead, len);