From: Ian Jackson Date: Fri, 19 Sep 2014 20:02:47 +0000 (+0100) Subject: resolver: Support IPv6 literals X-Git-Tag: v0.4.0_beta2~110 X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=secnet.git;a=commitdiff_plain;h=3f2c70f6b6d5ba48ff9fbe7887eb2e77ea128220 resolver: Support IPv6 literals With CONFIG_IPV6, use adns_addr2text instead of inet_ntoa. Signed-off-by: Ian Jackson --- diff --git a/resolver.c b/resolver.c index 83afd2f..6088c56 100644 --- a/resolver.c +++ b/resolver.c @@ -34,8 +34,13 @@ static bool_t resolve_request(void *sst, cstring_t name, struct adns *st=sst; struct query *q; int rv; - const int maxlitlen=50; - + const int maxlitlen= +#ifdef CONFIG_IPV6 + ADNS_ADDR2TEXT_BUFLEN*2 +#else + 50 +#endif + ; ssize_t l=strlen(name); if (name[0]=='[' && l2 && name[l-1]==']') { char trimmed[maxlitlen+1]; @@ -44,12 +49,28 @@ static bool_t resolve_request(void *sst, cstring_t name, struct comm_addr ca; ca.comm=comm; ca.ix=-1; +#ifdef CONFIG_IPV6 + socklen_t salen=sizeof(ca.ia); + rv=adns_text2addr(trimmed, port, adns_qf_addrlit_ipv4_quadonly, + &ca.ia.sa, &salen); + assert(rv!=ENOSPC); + if (rv) { + char msg[250]; + snprintf(msg,sizeof(msg),"invalid address literal: %s", + strerror(rv)); + msg[sizeof(msg)-1]=0; + cb(cst,0,0,0,msg); + } else { + cb(cst,&ca,1,1,0); + } +#else ca.ia.sin.sin_family=AF_INET; ca.ia.sin.sin_port=htons(port); if (inet_aton(trimmed,&ca.ia.sin.sin_addr)) cb(cst,&ca,1,1,0); else cb(cst,0,0,0,"invalid IP address"); +#endif return True; }