11363f04cSPaul Traina /*- 21363f04cSPaul Traina * Copyright (c) 1985, 1988, 1993 31363f04cSPaul Traina * The Regents of the University of California. All rights reserved. 41363f04cSPaul Traina * 51363f04cSPaul Traina * Redistribution and use in source and binary forms, with or without 61363f04cSPaul Traina * modification, are permitted provided that the following conditions 71363f04cSPaul Traina * are met: 81363f04cSPaul Traina * 1. Redistributions of source code must retain the above copyright 91363f04cSPaul Traina * notice, this list of conditions and the following disclaimer. 101363f04cSPaul Traina * 2. Redistributions in binary form must reproduce the above copyright 111363f04cSPaul Traina * notice, this list of conditions and the following disclaimer in the 121363f04cSPaul Traina * documentation and/or other materials provided with the distribution. 131363f04cSPaul Traina * 3. All advertising materials mentioning features or use of this software 141363f04cSPaul Traina * must display the following acknowledgement: 151363f04cSPaul Traina * This product includes software developed by the University of 161363f04cSPaul Traina * California, Berkeley and its contributors. 171363f04cSPaul Traina * 4. Neither the name of the University nor the names of its contributors 181363f04cSPaul Traina * may be used to endorse or promote products derived from this software 191363f04cSPaul Traina * without specific prior written permission. 201363f04cSPaul Traina * 211363f04cSPaul Traina * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 221363f04cSPaul Traina * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 231363f04cSPaul Traina * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 241363f04cSPaul Traina * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 251363f04cSPaul Traina * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 261363f04cSPaul Traina * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 271363f04cSPaul Traina * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 281363f04cSPaul Traina * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 291363f04cSPaul Traina * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 301363f04cSPaul Traina * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 311363f04cSPaul Traina * SUCH DAMAGE. 321363f04cSPaul Traina * - 331363f04cSPaul Traina * Portions Copyright (c) 1993 by Digital Equipment Corporation. 341363f04cSPaul Traina * 351363f04cSPaul Traina * Permission to use, copy, modify, and distribute this software for any 361363f04cSPaul Traina * purpose with or without fee is hereby granted, provided that the above 371363f04cSPaul Traina * copyright notice and this permission notice appear in all copies, and that 381363f04cSPaul Traina * the name of Digital Equipment Corporation not be used in advertising or 391363f04cSPaul Traina * publicity pertaining to distribution of the document or software without 401363f04cSPaul Traina * specific, written prior permission. 411363f04cSPaul Traina * 421363f04cSPaul Traina * THE SOFTWARE IS PROVIDED "AS IS" AND DIGITAL EQUIPMENT CORP. DISCLAIMS ALL 431363f04cSPaul Traina * WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES 441363f04cSPaul Traina * OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL DIGITAL EQUIPMENT 451363f04cSPaul Traina * CORPORATION BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL 461363f04cSPaul Traina * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR 471363f04cSPaul Traina * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS 481363f04cSPaul Traina * ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS 491363f04cSPaul Traina * SOFTWARE. 501363f04cSPaul Traina * - 511363f04cSPaul Traina * --Copyright-- 521363f04cSPaul Traina */ 534faad310SPeter Wemm /* Portions Copyright (c) 1993 Carlos Leandro and Rui Salgueiro 544faad310SPeter Wemm * Dep. Matematica Universidade de Coimbra, Portugal, Europe 554faad310SPeter Wemm * 564faad310SPeter Wemm * Permission to use, copy, modify, and distribute this software for any 574faad310SPeter Wemm * purpose with or without fee is hereby granted, provided that the above 584faad310SPeter Wemm * copyright notice and this permission notice appear in all copies. 594faad310SPeter Wemm */ 601363f04cSPaul Traina 611363f04cSPaul Traina #if defined(LIBC_SCCS) && !defined(lint) 621363f04cSPaul Traina static char sccsid[] = "@(#)gethostnamadr.c 8.1 (Berkeley) 6/4/93"; 631363f04cSPaul Traina #endif /* LIBC_SCCS and not lint */ 64333fc21eSDavid E. O'Brien #include <sys/cdefs.h> 65333fc21eSDavid E. O'Brien __FBSDID("$FreeBSD$"); 661363f04cSPaul Traina 671363f04cSPaul Traina #include <sys/param.h> 681363f04cSPaul Traina #include <sys/socket.h> 691363f04cSPaul Traina #include <netinet/in.h> 701363f04cSPaul Traina #include <arpa/inet.h> 711363f04cSPaul Traina #include <arpa/nameser.h> 724faad310SPeter Wemm 73a54c3906SDiomidis Spinellis #include <errno.h> 744faad310SPeter Wemm #include <stdio.h> 75a52b6b83SHajimu UMEMOTO #include <stdlib.h> 761363f04cSPaul Traina #include <netdb.h> 771363f04cSPaul Traina #include <resolv.h> 781363f04cSPaul Traina #include <ctype.h> 791363f04cSPaul Traina #include <string.h> 804faad310SPeter Wemm #include <unistd.h> 811363f04cSPaul Traina #include <syslog.h> 82248aee62SJacques Vidrine #include <stdarg.h> 83248aee62SJacques Vidrine #include <nsswitch.h> 841363f04cSPaul Traina 85a2a77501SHajimu UMEMOTO #include "netdb_private.h" 864faad310SPeter Wemm #include "res_config.h" 871363f04cSPaul Traina 884faad310SPeter Wemm #define BYADDR 0 894faad310SPeter Wemm #define BYNAME 1 901363f04cSPaul Traina 91a52b6b83SHajimu UMEMOTO #define MAXPACKET (64*1024) 921363f04cSPaul Traina 931363f04cSPaul Traina typedef union { 941363f04cSPaul Traina HEADER hdr; 951363f04cSPaul Traina u_char buf[MAXPACKET]; 961363f04cSPaul Traina } querybuf; 971363f04cSPaul Traina 981363f04cSPaul Traina typedef union { 994faad310SPeter Wemm long al; 1001363f04cSPaul Traina char ac; 1011363f04cSPaul Traina } align; 1021363f04cSPaul Traina 103a54c3906SDiomidis Spinellis /* 104a54c3906SDiomidis Spinellis * Reverse the order of first four dotted entries of in. 105a54c3906SDiomidis Spinellis * Out must contain space for at least strlen(in) characters. 106a54c3906SDiomidis Spinellis * The result does not include any leading 0s of in. 107a54c3906SDiomidis Spinellis */ 10850a51e39SRuslan Ermilov static void 109a54c3906SDiomidis Spinellis ipreverse(char *in, char *out) 110a54c3906SDiomidis Spinellis { 111a54c3906SDiomidis Spinellis char *pos[4]; 112a54c3906SDiomidis Spinellis int len[4]; 113a54c3906SDiomidis Spinellis char *p, *start; 114a54c3906SDiomidis Spinellis int i = 0; 115a54c3906SDiomidis Spinellis int leading = 1; 116a54c3906SDiomidis Spinellis 117a54c3906SDiomidis Spinellis /* Fill-in element positions and lengths: pos[], len[]. */ 118a54c3906SDiomidis Spinellis start = p = in; 119a54c3906SDiomidis Spinellis for (;;) { 120a54c3906SDiomidis Spinellis if (*p == '.' || *p == '\0') { 121a54c3906SDiomidis Spinellis /* Leading 0? */ 122a54c3906SDiomidis Spinellis if (leading && p - start == 1 && *start == '0') 123a54c3906SDiomidis Spinellis len[i] = 0; 124a54c3906SDiomidis Spinellis else { 125a54c3906SDiomidis Spinellis len[i] = p - start; 126a54c3906SDiomidis Spinellis leading = 0; 127a54c3906SDiomidis Spinellis } 128a54c3906SDiomidis Spinellis pos[i] = start; 129a54c3906SDiomidis Spinellis start = p + 1; 130a54c3906SDiomidis Spinellis i++; 131a54c3906SDiomidis Spinellis } 132a54c3906SDiomidis Spinellis if (i == 4) 133a54c3906SDiomidis Spinellis break; 134a54c3906SDiomidis Spinellis if (*p == 0) { 135a54c3906SDiomidis Spinellis for (; i < 4; i++) { 136a54c3906SDiomidis Spinellis pos[i] = p; 137a54c3906SDiomidis Spinellis len[i] = 0; 138a54c3906SDiomidis Spinellis } 139a54c3906SDiomidis Spinellis break; 140a54c3906SDiomidis Spinellis } 141a54c3906SDiomidis Spinellis p++; 142a54c3906SDiomidis Spinellis } 143a54c3906SDiomidis Spinellis 144a54c3906SDiomidis Spinellis /* Copy the entries in reverse order */ 145a54c3906SDiomidis Spinellis p = out; 146a54c3906SDiomidis Spinellis leading = 1; 147a54c3906SDiomidis Spinellis for (i = 3; i >= 0; i--) { 148a54c3906SDiomidis Spinellis memcpy(p, pos[i], len[i]); 149a54c3906SDiomidis Spinellis if (len[i]) 150a54c3906SDiomidis Spinellis leading = 0; 151a54c3906SDiomidis Spinellis p += len[i]; 152a54c3906SDiomidis Spinellis /* Need a . separator? */ 153a54c3906SDiomidis Spinellis if (!leading && i > 0 && len[i - 1]) 154a54c3906SDiomidis Spinellis *p++ = '.'; 155a54c3906SDiomidis Spinellis } 156a54c3906SDiomidis Spinellis *p = '\0'; 157a54c3906SDiomidis Spinellis } 158a54c3906SDiomidis Spinellis 159a2a77501SHajimu UMEMOTO static int 160a2a77501SHajimu UMEMOTO getnetanswer(querybuf *answer, int anslen, int net_i, struct netent *ne, 1615342d17fSHajimu UMEMOTO struct netent_data *ned, res_state statp) 1621363f04cSPaul Traina { 1631363f04cSPaul Traina 1648fb3f3f6SDavid E. O'Brien HEADER *hp; 1658fb3f3f6SDavid E. O'Brien u_char *cp; 1668fb3f3f6SDavid E. O'Brien int n; 1671363f04cSPaul Traina u_char *eom; 16850a51e39SRuslan Ermilov int type, class, ancount, qdcount, haveanswer; 169a54c3906SDiomidis Spinellis char aux[MAXHOSTNAMELEN]; 170a2a77501SHajimu UMEMOTO char ans[MAXHOSTNAMELEN]; 171a54c3906SDiomidis Spinellis char *in, *bp, *ep, **ap; 1721363f04cSPaul Traina 1731363f04cSPaul Traina /* 1741363f04cSPaul Traina * find first satisfactory answer 1751363f04cSPaul Traina * 1761363f04cSPaul Traina * answer --> +------------+ ( MESSAGE ) 1771363f04cSPaul Traina * | Header | 1781363f04cSPaul Traina * +------------+ 1791363f04cSPaul Traina * | Question | the question for the name server 1801363f04cSPaul Traina * +------------+ 1811363f04cSPaul Traina * | Answer | RRs answering the question 1821363f04cSPaul Traina * +------------+ 1831363f04cSPaul Traina * | Authority | RRs pointing toward an authority 1841363f04cSPaul Traina * | Additional | RRs holding additional information 1851363f04cSPaul Traina * +------------+ 1861363f04cSPaul Traina */ 1871363f04cSPaul Traina eom = answer->buf + anslen; 1881363f04cSPaul Traina hp = &answer->hdr; 1891363f04cSPaul Traina ancount = ntohs(hp->ancount); /* #/records in the answer section */ 1901363f04cSPaul Traina qdcount = ntohs(hp->qdcount); /* #/entries in the question section */ 191a2a77501SHajimu UMEMOTO bp = ned->netbuf; 192a2a77501SHajimu UMEMOTO ep = ned->netbuf + sizeof(ned->netbuf); 1931363f04cSPaul Traina cp = answer->buf + HFIXEDSZ; 1941363f04cSPaul Traina if (!qdcount) { 1951363f04cSPaul Traina if (hp->aa) 1965342d17fSHajimu UMEMOTO RES_SET_H_ERRNO(statp, HOST_NOT_FOUND); 1971363f04cSPaul Traina else 1985342d17fSHajimu UMEMOTO RES_SET_H_ERRNO(statp, TRY_AGAIN); 199a2a77501SHajimu UMEMOTO return -1; 2001363f04cSPaul Traina } 2014faad310SPeter Wemm while (qdcount-- > 0) 2021363f04cSPaul Traina cp += __dn_skipname(cp, eom) + QFIXEDSZ; 203a2a77501SHajimu UMEMOTO ap = ned->net_aliases; 2041363f04cSPaul Traina *ap = NULL; 205a2a77501SHajimu UMEMOTO ne->n_aliases = ned->net_aliases; 2061363f04cSPaul Traina haveanswer = 0; 2071363f04cSPaul Traina while (--ancount >= 0 && cp < eom) { 208d6af58f5SWarner Losh n = dn_expand(answer->buf, eom, cp, bp, ep - bp); 2095ce1c533SPeter Wemm if ((n < 0) || !res_dnok(bp)) 2101363f04cSPaul Traina break; 2111363f04cSPaul Traina cp += n; 2121363f04cSPaul Traina ans[0] = '\0'; 2133c8e19e1SWarner Losh (void)strncpy(&ans[0], bp, sizeof(ans) - 1); 2143c8e19e1SWarner Losh ans[sizeof(ans) - 1] = '\0'; 2151363f04cSPaul Traina GETSHORT(type, cp); 2161363f04cSPaul Traina GETSHORT(class, cp); 2171363f04cSPaul Traina cp += INT32SZ; /* TTL */ 2181363f04cSPaul Traina GETSHORT(n, cp); 2191363f04cSPaul Traina if (class == C_IN && type == T_PTR) { 220d6af58f5SWarner Losh n = dn_expand(answer->buf, eom, cp, bp, ep - bp); 2215ce1c533SPeter Wemm if ((n < 0) || !res_hnok(bp)) { 2221363f04cSPaul Traina cp += n; 223a2a77501SHajimu UMEMOTO return -1; 2241363f04cSPaul Traina } 2251363f04cSPaul Traina cp += n; 2261363f04cSPaul Traina *ap++ = bp; 2274cbd2472SWarner Losh n = strlen(bp) + 1; 2284cbd2472SWarner Losh bp += n; 229a2a77501SHajimu UMEMOTO ne->n_addrtype = (class == C_IN) ? AF_INET : AF_UNSPEC; 2301363f04cSPaul Traina haveanswer++; 2311363f04cSPaul Traina } 2321363f04cSPaul Traina } 2331363f04cSPaul Traina if (haveanswer) { 2341363f04cSPaul Traina *ap = NULL; 2351363f04cSPaul Traina switch (net_i) { 2361363f04cSPaul Traina case BYADDR: 237a2a77501SHajimu UMEMOTO ne->n_name = *ne->n_aliases; 238a2a77501SHajimu UMEMOTO ne->n_net = 0L; 2391363f04cSPaul Traina break; 2401363f04cSPaul Traina case BYNAME: 241a2a77501SHajimu UMEMOTO in = *ne->n_aliases; 242a2a77501SHajimu UMEMOTO n = strlen(ans) + 1; 243a2a77501SHajimu UMEMOTO if (ep - bp < n) { 2445342d17fSHajimu UMEMOTO RES_SET_H_ERRNO(statp, NETDB_INTERNAL); 245a2a77501SHajimu UMEMOTO errno = ENOBUFS; 246a2a77501SHajimu UMEMOTO return -1; 247a2a77501SHajimu UMEMOTO } 248a2a77501SHajimu UMEMOTO strlcpy(bp, ans, ep - bp); 249a2a77501SHajimu UMEMOTO ne->n_name = bp; 250a54c3906SDiomidis Spinellis if (strlen(in) + 1 > sizeof(aux)) { 2515342d17fSHajimu UMEMOTO RES_SET_H_ERRNO(statp, NETDB_INTERNAL); 252a54c3906SDiomidis Spinellis errno = ENOBUFS; 253a2a77501SHajimu UMEMOTO return -1; 2541363f04cSPaul Traina } 255a54c3906SDiomidis Spinellis ipreverse(in, aux); 256a2a77501SHajimu UMEMOTO ne->n_net = inet_network(aux); 2574faad310SPeter Wemm break; 2581363f04cSPaul Traina } 259a2a77501SHajimu UMEMOTO ne->n_aliases++; 260a2a77501SHajimu UMEMOTO return 0; 2611363f04cSPaul Traina } 2625342d17fSHajimu UMEMOTO RES_SET_H_ERRNO(statp, TRY_AGAIN); 263a2a77501SHajimu UMEMOTO return -1; 2641363f04cSPaul Traina } 2651363f04cSPaul Traina 266248aee62SJacques Vidrine int 267248aee62SJacques Vidrine _dns_getnetbyaddr(void *rval, void *cb_data, va_list ap) 2681363f04cSPaul Traina { 269036ae3ddSHajimu UMEMOTO uint32_t net; 270248aee62SJacques Vidrine int net_type; 271a2a77501SHajimu UMEMOTO struct netent *ne; 272a2a77501SHajimu UMEMOTO struct netent_data *ned; 2731363f04cSPaul Traina unsigned int netbr[4]; 274a2a77501SHajimu UMEMOTO int nn, anslen, error; 275a52b6b83SHajimu UMEMOTO querybuf *buf; 2761363f04cSPaul Traina char qbuf[MAXDNAME]; 277036ae3ddSHajimu UMEMOTO uint32_t net2; 2785342d17fSHajimu UMEMOTO res_state statp; 2791363f04cSPaul Traina 280036ae3ddSHajimu UMEMOTO net = va_arg(ap, uint32_t); 281248aee62SJacques Vidrine net_type = va_arg(ap, int); 282a2a77501SHajimu UMEMOTO ne = va_arg(ap, struct netent *); 283a2a77501SHajimu UMEMOTO ned = va_arg(ap, struct netent_data *); 284248aee62SJacques Vidrine 2851363f04cSPaul Traina if (net_type != AF_INET) 286248aee62SJacques Vidrine return NS_UNAVAIL; 2871363f04cSPaul Traina 2885342d17fSHajimu UMEMOTO statp = __res_state(); 2895342d17fSHajimu UMEMOTO if ((statp->options & RES_INIT) == 0 && res_ninit(statp) == -1) { 2905342d17fSHajimu UMEMOTO RES_SET_H_ERRNO(statp, NETDB_INTERNAL); 2915342d17fSHajimu UMEMOTO return NS_UNAVAIL; 2925342d17fSHajimu UMEMOTO } 2935342d17fSHajimu UMEMOTO 2944faad310SPeter Wemm for (nn = 4, net2 = net; net2; net2 >>= 8) 2951363f04cSPaul Traina netbr[--nn] = net2 & 0xff; 2961363f04cSPaul Traina switch (nn) { 2971363f04cSPaul Traina case 3: /* Class A */ 2984faad310SPeter Wemm sprintf(qbuf, "0.0.0.%u.in-addr.arpa", netbr[3]); 2991363f04cSPaul Traina break; 3001363f04cSPaul Traina case 2: /* Class B */ 3014faad310SPeter Wemm sprintf(qbuf, "0.0.%u.%u.in-addr.arpa", netbr[3], netbr[2]); 3021363f04cSPaul Traina break; 3031363f04cSPaul Traina case 1: /* Class C */ 3044faad310SPeter Wemm sprintf(qbuf, "0.%u.%u.%u.in-addr.arpa", netbr[3], netbr[2], 3054faad310SPeter Wemm netbr[1]); 3061363f04cSPaul Traina break; 3071363f04cSPaul Traina case 0: /* Class D - E */ 3084faad310SPeter Wemm sprintf(qbuf, "%u.%u.%u.%u.in-addr.arpa", netbr[3], netbr[2], 3094faad310SPeter Wemm netbr[1], netbr[0]); 3101363f04cSPaul Traina break; 3111363f04cSPaul Traina } 312a52b6b83SHajimu UMEMOTO if ((buf = malloc(sizeof(*buf))) == NULL) { 3135342d17fSHajimu UMEMOTO RES_SET_H_ERRNO(statp, NETDB_INTERNAL); 314a52b6b83SHajimu UMEMOTO return NS_NOTFOUND; 315a52b6b83SHajimu UMEMOTO } 3165342d17fSHajimu UMEMOTO anslen = res_nquery(statp, qbuf, C_IN, T_PTR, (u_char *)buf, 3175342d17fSHajimu UMEMOTO sizeof(*buf)); 3181363f04cSPaul Traina if (anslen < 0) { 319a52b6b83SHajimu UMEMOTO free(buf); 3204faad310SPeter Wemm #ifdef DEBUG 3215342d17fSHajimu UMEMOTO if (statp->options & RES_DEBUG) 3225342d17fSHajimu UMEMOTO printf("res_nsearch failed\n"); 32354384cf3SJacques Vidrine #endif 32454384cf3SJacques Vidrine return NS_UNAVAIL; 325a52b6b83SHajimu UMEMOTO } else if (anslen > sizeof(*buf)) { 326a52b6b83SHajimu UMEMOTO free(buf); 32754384cf3SJacques Vidrine #ifdef DEBUG 3285342d17fSHajimu UMEMOTO if (statp->options & RES_DEBUG) 3295342d17fSHajimu UMEMOTO printf("res_nsearch static buffer too small\n"); 3304faad310SPeter Wemm #endif 331248aee62SJacques Vidrine return NS_UNAVAIL; 3321363f04cSPaul Traina } 3335342d17fSHajimu UMEMOTO error = getnetanswer(buf, anslen, BYADDR, ne, ned, statp); 334a52b6b83SHajimu UMEMOTO free(buf); 335a2a77501SHajimu UMEMOTO if (error == 0) { 3361363f04cSPaul Traina /* Strip trailing zeros */ 337036ae3ddSHajimu UMEMOTO while ((net & 0xff) == 0 && net != 0) 338036ae3ddSHajimu UMEMOTO net >>= 8; 339036ae3ddSHajimu UMEMOTO ne->n_net = net; 340248aee62SJacques Vidrine return NS_SUCCESS; 3411363f04cSPaul Traina } 342248aee62SJacques Vidrine return NS_NOTFOUND; 3434faad310SPeter Wemm } 3441363f04cSPaul Traina 345248aee62SJacques Vidrine int 346248aee62SJacques Vidrine _dns_getnetbyname(void *rval, void *cb_data, va_list ap) 3471363f04cSPaul Traina { 348248aee62SJacques Vidrine const char *net; 349a2a77501SHajimu UMEMOTO struct netent *ne; 350a2a77501SHajimu UMEMOTO struct netent_data *ned; 351a2a77501SHajimu UMEMOTO int anslen, error; 352a52b6b83SHajimu UMEMOTO querybuf *buf; 3531363f04cSPaul Traina char qbuf[MAXDNAME]; 3545342d17fSHajimu UMEMOTO res_state statp; 3551363f04cSPaul Traina 356248aee62SJacques Vidrine net = va_arg(ap, const char *); 357a2a77501SHajimu UMEMOTO ne = va_arg(ap, struct netent *); 358a2a77501SHajimu UMEMOTO ned = va_arg(ap, struct netent_data *); 359248aee62SJacques Vidrine 3605342d17fSHajimu UMEMOTO statp = __res_state(); 3615342d17fSHajimu UMEMOTO if ((statp->options & RES_INIT) == 0 && res_ninit(statp) == -1) { 3625342d17fSHajimu UMEMOTO RES_SET_H_ERRNO(statp, NETDB_INTERNAL); 363248aee62SJacques Vidrine return NS_UNAVAIL; 3644faad310SPeter Wemm } 365a52b6b83SHajimu UMEMOTO if ((buf = malloc(sizeof(*buf))) == NULL) { 3665342d17fSHajimu UMEMOTO RES_SET_H_ERRNO(statp, NETDB_INTERNAL); 367a52b6b83SHajimu UMEMOTO return NS_NOTFOUND; 368a52b6b83SHajimu UMEMOTO } 3693c8e19e1SWarner Losh strncpy(qbuf, net, sizeof(qbuf) - 1); 3703c8e19e1SWarner Losh qbuf[sizeof(qbuf) - 1] = '\0'; 3715342d17fSHajimu UMEMOTO anslen = res_nsearch(statp, qbuf, C_IN, T_PTR, (u_char *)buf, 3725342d17fSHajimu UMEMOTO sizeof(*buf)); 3731363f04cSPaul Traina if (anslen < 0) { 374a52b6b83SHajimu UMEMOTO free(buf); 3754faad310SPeter Wemm #ifdef DEBUG 3765342d17fSHajimu UMEMOTO if (statp->options & RES_DEBUG) 3775342d17fSHajimu UMEMOTO printf("res_nsearch failed\n"); 37854384cf3SJacques Vidrine #endif 37954384cf3SJacques Vidrine return NS_UNAVAIL; 380a52b6b83SHajimu UMEMOTO } else if (anslen > sizeof(*buf)) { 381a52b6b83SHajimu UMEMOTO free(buf); 38254384cf3SJacques Vidrine #ifdef DEBUG 3835342d17fSHajimu UMEMOTO if (statp->options & RES_DEBUG) 3847922d4cfSJacques Vidrine printf("res_search static buffer too small\n"); 3854faad310SPeter Wemm #endif 386248aee62SJacques Vidrine return NS_UNAVAIL; 3871363f04cSPaul Traina } 3885342d17fSHajimu UMEMOTO error = getnetanswer(buf, anslen, BYNAME, ne, ned, statp); 389a52b6b83SHajimu UMEMOTO free(buf); 390a2a77501SHajimu UMEMOTO return (error == 0) ? NS_SUCCESS : NS_NOTFOUND; 3911363f04cSPaul Traina } 3921363f04cSPaul Traina 3931363f04cSPaul Traina void 3941363f04cSPaul Traina _setnetdnsent(stayopen) 3951363f04cSPaul Traina int stayopen; 3961363f04cSPaul Traina { 3975342d17fSHajimu UMEMOTO res_state statp; 3985342d17fSHajimu UMEMOTO 3995342d17fSHajimu UMEMOTO statp = __res_state(); 4005342d17fSHajimu UMEMOTO if ((statp->options & RES_INIT) == 0 && res_ninit(statp) == -1) 4015342d17fSHajimu UMEMOTO return; 4021363f04cSPaul Traina if (stayopen) 4035342d17fSHajimu UMEMOTO statp->options |= RES_STAYOPEN | RES_USEVC; 4041363f04cSPaul Traina } 4051363f04cSPaul Traina 4061363f04cSPaul Traina void 4071363f04cSPaul Traina _endnetdnsent() 4081363f04cSPaul Traina { 4095342d17fSHajimu UMEMOTO res_state statp; 4105342d17fSHajimu UMEMOTO 4115342d17fSHajimu UMEMOTO statp = __res_state(); 4125342d17fSHajimu UMEMOTO statp->options &= ~(RES_STAYOPEN | RES_USEVC); 4135342d17fSHajimu UMEMOTO res_nclose(statp); 4141363f04cSPaul Traina } 415