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 * 4. Neither the name of the University nor the names of its contributors 141363f04cSPaul Traina * may be used to endorse or promote products derived from this software 151363f04cSPaul Traina * without specific prior written permission. 161363f04cSPaul Traina * 171363f04cSPaul Traina * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 181363f04cSPaul Traina * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 191363f04cSPaul Traina * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 201363f04cSPaul Traina * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 211363f04cSPaul Traina * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 221363f04cSPaul Traina * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 231363f04cSPaul Traina * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 241363f04cSPaul Traina * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 251363f04cSPaul Traina * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 261363f04cSPaul Traina * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 271363f04cSPaul Traina * SUCH DAMAGE. 281363f04cSPaul Traina * - 291363f04cSPaul Traina * Portions Copyright (c) 1993 by Digital Equipment Corporation. 301363f04cSPaul Traina * 311363f04cSPaul Traina * Permission to use, copy, modify, and distribute this software for any 321363f04cSPaul Traina * purpose with or without fee is hereby granted, provided that the above 331363f04cSPaul Traina * copyright notice and this permission notice appear in all copies, and that 341363f04cSPaul Traina * the name of Digital Equipment Corporation not be used in advertising or 351363f04cSPaul Traina * publicity pertaining to distribution of the document or software without 361363f04cSPaul Traina * specific, written prior permission. 371363f04cSPaul Traina * 381363f04cSPaul Traina * THE SOFTWARE IS PROVIDED "AS IS" AND DIGITAL EQUIPMENT CORP. DISCLAIMS ALL 391363f04cSPaul Traina * WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES 401363f04cSPaul Traina * OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL DIGITAL EQUIPMENT 411363f04cSPaul Traina * CORPORATION BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL 421363f04cSPaul Traina * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR 431363f04cSPaul Traina * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS 441363f04cSPaul Traina * ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS 451363f04cSPaul Traina * SOFTWARE. 461363f04cSPaul Traina * - 471363f04cSPaul Traina * --Copyright-- 481363f04cSPaul Traina */ 494faad310SPeter Wemm /* Portions Copyright (c) 1993 Carlos Leandro and Rui Salgueiro 504faad310SPeter Wemm * Dep. Matematica Universidade de Coimbra, Portugal, Europe 514faad310SPeter Wemm * 524faad310SPeter Wemm * Permission to use, copy, modify, and distribute this software for any 534faad310SPeter Wemm * purpose with or without fee is hereby granted, provided that the above 544faad310SPeter Wemm * copyright notice and this permission notice appear in all copies. 554faad310SPeter Wemm */ 561363f04cSPaul Traina 571363f04cSPaul Traina #if defined(LIBC_SCCS) && !defined(lint) 581363f04cSPaul Traina static char sccsid[] = "@(#)gethostnamadr.c 8.1 (Berkeley) 6/4/93"; 591363f04cSPaul Traina #endif /* LIBC_SCCS and not lint */ 60333fc21eSDavid E. O'Brien #include <sys/cdefs.h> 61333fc21eSDavid E. O'Brien __FBSDID("$FreeBSD$"); 621363f04cSPaul Traina 631363f04cSPaul Traina #include <sys/param.h> 641363f04cSPaul Traina #include <sys/socket.h> 651363f04cSPaul Traina #include <netinet/in.h> 661363f04cSPaul Traina #include <arpa/inet.h> 671363f04cSPaul Traina #include <arpa/nameser.h> 684faad310SPeter Wemm 69a54c3906SDiomidis Spinellis #include <errno.h> 704faad310SPeter Wemm #include <stdio.h> 71a52b6b83SHajimu UMEMOTO #include <stdlib.h> 721363f04cSPaul Traina #include <netdb.h> 731363f04cSPaul Traina #include <resolv.h> 741363f04cSPaul Traina #include <ctype.h> 751363f04cSPaul Traina #include <string.h> 764faad310SPeter Wemm #include <unistd.h> 771363f04cSPaul Traina #include <syslog.h> 78248aee62SJacques Vidrine #include <stdarg.h> 79248aee62SJacques Vidrine #include <nsswitch.h> 801363f04cSPaul Traina 81a2a77501SHajimu UMEMOTO #include "netdb_private.h" 824faad310SPeter Wemm #include "res_config.h" 831363f04cSPaul Traina 844faad310SPeter Wemm #define BYADDR 0 854faad310SPeter Wemm #define BYNAME 1 861363f04cSPaul Traina 87a52b6b83SHajimu UMEMOTO #define MAXPACKET (64*1024) 881363f04cSPaul Traina 891363f04cSPaul Traina typedef union { 901363f04cSPaul Traina HEADER hdr; 911363f04cSPaul Traina u_char buf[MAXPACKET]; 921363f04cSPaul Traina } querybuf; 931363f04cSPaul Traina 941363f04cSPaul Traina typedef union { 954faad310SPeter Wemm long al; 961363f04cSPaul Traina char ac; 971363f04cSPaul Traina } align; 981363f04cSPaul Traina 99a54c3906SDiomidis Spinellis /* 100a54c3906SDiomidis Spinellis * Reverse the order of first four dotted entries of in. 101a54c3906SDiomidis Spinellis * Out must contain space for at least strlen(in) characters. 102a54c3906SDiomidis Spinellis * The result does not include any leading 0s of in. 103a54c3906SDiomidis Spinellis */ 10450a51e39SRuslan Ermilov static void 105a54c3906SDiomidis Spinellis ipreverse(char *in, char *out) 106a54c3906SDiomidis Spinellis { 107a54c3906SDiomidis Spinellis char *pos[4]; 108a54c3906SDiomidis Spinellis int len[4]; 109a54c3906SDiomidis Spinellis char *p, *start; 110a54c3906SDiomidis Spinellis int i = 0; 111a54c3906SDiomidis Spinellis int leading = 1; 112a54c3906SDiomidis Spinellis 113a54c3906SDiomidis Spinellis /* Fill-in element positions and lengths: pos[], len[]. */ 114a54c3906SDiomidis Spinellis start = p = in; 115a54c3906SDiomidis Spinellis for (;;) { 116a54c3906SDiomidis Spinellis if (*p == '.' || *p == '\0') { 117a54c3906SDiomidis Spinellis /* Leading 0? */ 118a54c3906SDiomidis Spinellis if (leading && p - start == 1 && *start == '0') 119a54c3906SDiomidis Spinellis len[i] = 0; 120a54c3906SDiomidis Spinellis else { 121a54c3906SDiomidis Spinellis len[i] = p - start; 122a54c3906SDiomidis Spinellis leading = 0; 123a54c3906SDiomidis Spinellis } 124a54c3906SDiomidis Spinellis pos[i] = start; 125a54c3906SDiomidis Spinellis start = p + 1; 126a54c3906SDiomidis Spinellis i++; 127a54c3906SDiomidis Spinellis } 128a54c3906SDiomidis Spinellis if (i == 4) 129a54c3906SDiomidis Spinellis break; 130a54c3906SDiomidis Spinellis if (*p == 0) { 131a54c3906SDiomidis Spinellis for (; i < 4; i++) { 132a54c3906SDiomidis Spinellis pos[i] = p; 133a54c3906SDiomidis Spinellis len[i] = 0; 134a54c3906SDiomidis Spinellis } 135a54c3906SDiomidis Spinellis break; 136a54c3906SDiomidis Spinellis } 137a54c3906SDiomidis Spinellis p++; 138a54c3906SDiomidis Spinellis } 139a54c3906SDiomidis Spinellis 140a54c3906SDiomidis Spinellis /* Copy the entries in reverse order */ 141a54c3906SDiomidis Spinellis p = out; 142a54c3906SDiomidis Spinellis leading = 1; 143a54c3906SDiomidis Spinellis for (i = 3; i >= 0; i--) { 144a54c3906SDiomidis Spinellis memcpy(p, pos[i], len[i]); 145a54c3906SDiomidis Spinellis if (len[i]) 146a54c3906SDiomidis Spinellis leading = 0; 147a54c3906SDiomidis Spinellis p += len[i]; 148a54c3906SDiomidis Spinellis /* Need a . separator? */ 149a54c3906SDiomidis Spinellis if (!leading && i > 0 && len[i - 1]) 150a54c3906SDiomidis Spinellis *p++ = '.'; 151a54c3906SDiomidis Spinellis } 152a54c3906SDiomidis Spinellis *p = '\0'; 153a54c3906SDiomidis Spinellis } 154a54c3906SDiomidis Spinellis 155a2a77501SHajimu UMEMOTO static int 156a2a77501SHajimu UMEMOTO getnetanswer(querybuf *answer, int anslen, int net_i, struct netent *ne, 1575342d17fSHajimu UMEMOTO struct netent_data *ned, res_state statp) 1581363f04cSPaul Traina { 1591363f04cSPaul Traina 1608fb3f3f6SDavid E. O'Brien HEADER *hp; 1618fb3f3f6SDavid E. O'Brien u_char *cp; 1628fb3f3f6SDavid E. O'Brien int n; 1631363f04cSPaul Traina u_char *eom; 16450a51e39SRuslan Ermilov int type, class, ancount, qdcount, haveanswer; 165a54c3906SDiomidis Spinellis char aux[MAXHOSTNAMELEN]; 166a2a77501SHajimu UMEMOTO char ans[MAXHOSTNAMELEN]; 167a54c3906SDiomidis Spinellis char *in, *bp, *ep, **ap; 1681363f04cSPaul Traina 1691363f04cSPaul Traina /* 1701363f04cSPaul Traina * find first satisfactory answer 1711363f04cSPaul Traina * 1721363f04cSPaul Traina * answer --> +------------+ ( MESSAGE ) 1731363f04cSPaul Traina * | Header | 1741363f04cSPaul Traina * +------------+ 1751363f04cSPaul Traina * | Question | the question for the name server 1761363f04cSPaul Traina * +------------+ 1771363f04cSPaul Traina * | Answer | RRs answering the question 1781363f04cSPaul Traina * +------------+ 1791363f04cSPaul Traina * | Authority | RRs pointing toward an authority 1801363f04cSPaul Traina * | Additional | RRs holding additional information 1811363f04cSPaul Traina * +------------+ 1821363f04cSPaul Traina */ 1831363f04cSPaul Traina eom = answer->buf + anslen; 1841363f04cSPaul Traina hp = &answer->hdr; 1851363f04cSPaul Traina ancount = ntohs(hp->ancount); /* #/records in the answer section */ 1861363f04cSPaul Traina qdcount = ntohs(hp->qdcount); /* #/entries in the question section */ 187a2a77501SHajimu UMEMOTO bp = ned->netbuf; 188a2a77501SHajimu UMEMOTO ep = ned->netbuf + sizeof(ned->netbuf); 1891363f04cSPaul Traina cp = answer->buf + HFIXEDSZ; 1901363f04cSPaul Traina if (!qdcount) { 1911363f04cSPaul Traina if (hp->aa) 1925342d17fSHajimu UMEMOTO RES_SET_H_ERRNO(statp, HOST_NOT_FOUND); 1931363f04cSPaul Traina else 1945342d17fSHajimu UMEMOTO RES_SET_H_ERRNO(statp, TRY_AGAIN); 195d3ac2b30SHajimu UMEMOTO return (-1); 1961363f04cSPaul Traina } 1974faad310SPeter Wemm while (qdcount-- > 0) 1981363f04cSPaul Traina cp += __dn_skipname(cp, eom) + QFIXEDSZ; 199a2a77501SHajimu UMEMOTO ap = ned->net_aliases; 2001363f04cSPaul Traina *ap = NULL; 201a2a77501SHajimu UMEMOTO ne->n_aliases = ned->net_aliases; 2021363f04cSPaul Traina haveanswer = 0; 2031363f04cSPaul Traina while (--ancount >= 0 && cp < eom) { 204d6af58f5SWarner Losh n = dn_expand(answer->buf, eom, cp, bp, ep - bp); 2055ce1c533SPeter Wemm if ((n < 0) || !res_dnok(bp)) 2061363f04cSPaul Traina break; 2071363f04cSPaul Traina cp += n; 2081363f04cSPaul Traina ans[0] = '\0'; 2093c8e19e1SWarner Losh (void)strncpy(&ans[0], bp, sizeof(ans) - 1); 2103c8e19e1SWarner Losh ans[sizeof(ans) - 1] = '\0'; 2111363f04cSPaul Traina GETSHORT(type, cp); 2121363f04cSPaul Traina GETSHORT(class, cp); 2131363f04cSPaul Traina cp += INT32SZ; /* TTL */ 2141363f04cSPaul Traina GETSHORT(n, cp); 2151363f04cSPaul Traina if (class == C_IN && type == T_PTR) { 216d6af58f5SWarner Losh n = dn_expand(answer->buf, eom, cp, bp, ep - bp); 2175ce1c533SPeter Wemm if ((n < 0) || !res_hnok(bp)) { 2181363f04cSPaul Traina cp += n; 219d3ac2b30SHajimu UMEMOTO return (-1); 2201363f04cSPaul Traina } 2211363f04cSPaul Traina cp += n; 2221363f04cSPaul Traina *ap++ = bp; 2234cbd2472SWarner Losh n = strlen(bp) + 1; 2244cbd2472SWarner Losh bp += n; 225a2a77501SHajimu UMEMOTO ne->n_addrtype = (class == C_IN) ? AF_INET : AF_UNSPEC; 2261363f04cSPaul Traina haveanswer++; 2271363f04cSPaul Traina } 2281363f04cSPaul Traina } 2291363f04cSPaul Traina if (haveanswer) { 2301363f04cSPaul Traina *ap = NULL; 2311363f04cSPaul Traina switch (net_i) { 2321363f04cSPaul Traina case BYADDR: 233a2a77501SHajimu UMEMOTO ne->n_name = *ne->n_aliases; 234a2a77501SHajimu UMEMOTO ne->n_net = 0L; 2351363f04cSPaul Traina break; 2361363f04cSPaul Traina case BYNAME: 237a2a77501SHajimu UMEMOTO in = *ne->n_aliases; 238a2a77501SHajimu UMEMOTO n = strlen(ans) + 1; 239a2a77501SHajimu UMEMOTO if (ep - bp < n) { 2405342d17fSHajimu UMEMOTO RES_SET_H_ERRNO(statp, NETDB_INTERNAL); 241a2a77501SHajimu UMEMOTO errno = ENOBUFS; 242d3ac2b30SHajimu UMEMOTO return (-1); 243a2a77501SHajimu UMEMOTO } 244a2a77501SHajimu UMEMOTO strlcpy(bp, ans, ep - bp); 245a2a77501SHajimu UMEMOTO ne->n_name = bp; 246a54c3906SDiomidis Spinellis if (strlen(in) + 1 > sizeof(aux)) { 2475342d17fSHajimu UMEMOTO RES_SET_H_ERRNO(statp, NETDB_INTERNAL); 248a54c3906SDiomidis Spinellis errno = ENOBUFS; 249d3ac2b30SHajimu UMEMOTO return (-1); 2501363f04cSPaul Traina } 251a54c3906SDiomidis Spinellis ipreverse(in, aux); 252a2a77501SHajimu UMEMOTO ne->n_net = inet_network(aux); 2534faad310SPeter Wemm break; 2541363f04cSPaul Traina } 255a2a77501SHajimu UMEMOTO ne->n_aliases++; 256d3ac2b30SHajimu UMEMOTO return (0); 2571363f04cSPaul Traina } 2585342d17fSHajimu UMEMOTO RES_SET_H_ERRNO(statp, TRY_AGAIN); 259d3ac2b30SHajimu UMEMOTO return (-1); 2601363f04cSPaul Traina } 2611363f04cSPaul Traina 262248aee62SJacques Vidrine int 263248aee62SJacques Vidrine _dns_getnetbyaddr(void *rval, void *cb_data, va_list ap) 2641363f04cSPaul Traina { 265036ae3ddSHajimu UMEMOTO uint32_t net; 266248aee62SJacques Vidrine int net_type; 267d3ac2b30SHajimu UMEMOTO char *buffer; 268d3ac2b30SHajimu UMEMOTO size_t buflen; 269d3ac2b30SHajimu UMEMOTO int *errnop, *h_errnop; 270d3ac2b30SHajimu UMEMOTO struct netent *nptr, ne; 271a2a77501SHajimu UMEMOTO struct netent_data *ned; 2721363f04cSPaul Traina unsigned int netbr[4]; 273a2a77501SHajimu UMEMOTO int nn, anslen, error; 274a52b6b83SHajimu UMEMOTO querybuf *buf; 2751363f04cSPaul Traina char qbuf[MAXDNAME]; 276036ae3ddSHajimu UMEMOTO uint32_t net2; 2775342d17fSHajimu UMEMOTO res_state statp; 2781363f04cSPaul Traina 279036ae3ddSHajimu UMEMOTO net = va_arg(ap, uint32_t); 280248aee62SJacques Vidrine net_type = va_arg(ap, int); 281d3ac2b30SHajimu UMEMOTO nptr = va_arg(ap, struct netent *); 282d3ac2b30SHajimu UMEMOTO buffer = va_arg(ap, char *); 283d3ac2b30SHajimu UMEMOTO buflen = va_arg(ap, size_t); 284d3ac2b30SHajimu UMEMOTO errnop = va_arg(ap, int *); 285d3ac2b30SHajimu UMEMOTO h_errnop = va_arg(ap, int *); 2861363f04cSPaul Traina 2875342d17fSHajimu UMEMOTO statp = __res_state(); 2885342d17fSHajimu UMEMOTO if ((statp->options & RES_INIT) == 0 && res_ninit(statp) == -1) { 2895342d17fSHajimu UMEMOTO RES_SET_H_ERRNO(statp, NETDB_INTERNAL); 290d3ac2b30SHajimu UMEMOTO *h_errnop = statp->res_h_errno; 291d3ac2b30SHajimu UMEMOTO return (NS_UNAVAIL); 292d3ac2b30SHajimu UMEMOTO } 293d3ac2b30SHajimu UMEMOTO 294d3ac2b30SHajimu UMEMOTO if ((ned = __netent_data_init()) == NULL) { 295d3ac2b30SHajimu UMEMOTO RES_SET_H_ERRNO(statp, NETDB_INTERNAL); 296d3ac2b30SHajimu UMEMOTO *h_errnop = statp->res_h_errno; 297d3ac2b30SHajimu UMEMOTO return (NS_UNAVAIL); 298d3ac2b30SHajimu UMEMOTO } 299d3ac2b30SHajimu UMEMOTO 300d3ac2b30SHajimu UMEMOTO *((struct netent **)rval) = NULL; 301d3ac2b30SHajimu UMEMOTO 302d3ac2b30SHajimu UMEMOTO if (net_type != AF_INET) { 303d3ac2b30SHajimu UMEMOTO RES_SET_H_ERRNO(statp, NETDB_INTERNAL); 304d3ac2b30SHajimu UMEMOTO *h_errnop = statp->res_h_errno; 305d3ac2b30SHajimu UMEMOTO return (NS_UNAVAIL); 3065342d17fSHajimu UMEMOTO } 3075342d17fSHajimu UMEMOTO 3084faad310SPeter Wemm for (nn = 4, net2 = net; net2; net2 >>= 8) 3091363f04cSPaul Traina netbr[--nn] = net2 & 0xff; 3101363f04cSPaul Traina switch (nn) { 3111363f04cSPaul Traina case 3: /* Class A */ 3124faad310SPeter Wemm sprintf(qbuf, "0.0.0.%u.in-addr.arpa", netbr[3]); 3131363f04cSPaul Traina break; 3141363f04cSPaul Traina case 2: /* Class B */ 3154faad310SPeter Wemm sprintf(qbuf, "0.0.%u.%u.in-addr.arpa", netbr[3], netbr[2]); 3161363f04cSPaul Traina break; 3171363f04cSPaul Traina case 1: /* Class C */ 3184faad310SPeter Wemm sprintf(qbuf, "0.%u.%u.%u.in-addr.arpa", netbr[3], netbr[2], 3194faad310SPeter Wemm netbr[1]); 3201363f04cSPaul Traina break; 3211363f04cSPaul Traina case 0: /* Class D - E */ 3224faad310SPeter Wemm sprintf(qbuf, "%u.%u.%u.%u.in-addr.arpa", netbr[3], netbr[2], 3234faad310SPeter Wemm netbr[1], netbr[0]); 3241363f04cSPaul Traina break; 3251363f04cSPaul Traina } 326a52b6b83SHajimu UMEMOTO if ((buf = malloc(sizeof(*buf))) == NULL) { 3275342d17fSHajimu UMEMOTO RES_SET_H_ERRNO(statp, NETDB_INTERNAL); 328d3ac2b30SHajimu UMEMOTO *h_errnop = statp->res_h_errno; 329d3ac2b30SHajimu UMEMOTO return (NS_NOTFOUND); 330a52b6b83SHajimu UMEMOTO } 3315342d17fSHajimu UMEMOTO anslen = res_nquery(statp, qbuf, C_IN, T_PTR, (u_char *)buf, 3325342d17fSHajimu UMEMOTO sizeof(*buf)); 3331363f04cSPaul Traina if (anslen < 0) { 334a52b6b83SHajimu UMEMOTO free(buf); 3354faad310SPeter Wemm #ifdef DEBUG 3365342d17fSHajimu UMEMOTO if (statp->options & RES_DEBUG) 3375342d17fSHajimu UMEMOTO printf("res_nsearch failed\n"); 33854384cf3SJacques Vidrine #endif 339d3ac2b30SHajimu UMEMOTO *h_errnop = statp->res_h_errno; 340d3ac2b30SHajimu UMEMOTO return (NS_UNAVAIL); 341a52b6b83SHajimu UMEMOTO } else if (anslen > sizeof(*buf)) { 342a52b6b83SHajimu UMEMOTO free(buf); 34354384cf3SJacques Vidrine #ifdef DEBUG 3445342d17fSHajimu UMEMOTO if (statp->options & RES_DEBUG) 3455342d17fSHajimu UMEMOTO printf("res_nsearch static buffer too small\n"); 3464faad310SPeter Wemm #endif 347d3ac2b30SHajimu UMEMOTO *h_errnop = statp->res_h_errno; 348d3ac2b30SHajimu UMEMOTO return (NS_UNAVAIL); 3491363f04cSPaul Traina } 350d3ac2b30SHajimu UMEMOTO error = getnetanswer(buf, anslen, BYADDR, &ne, ned, statp); 351a52b6b83SHajimu UMEMOTO free(buf); 352a2a77501SHajimu UMEMOTO if (error == 0) { 3531363f04cSPaul Traina /* Strip trailing zeros */ 354036ae3ddSHajimu UMEMOTO while ((net & 0xff) == 0 && net != 0) 355036ae3ddSHajimu UMEMOTO net >>= 8; 356d3ac2b30SHajimu UMEMOTO ne.n_net = net; 357d3ac2b30SHajimu UMEMOTO if (__copy_netent(&ne, nptr, buffer, buflen) != 0) { 358225edeacSHajimu UMEMOTO *errnop = errno; 359225edeacSHajimu UMEMOTO RES_SET_H_ERRNO(statp, NETDB_INTERNAL); 360d3ac2b30SHajimu UMEMOTO *h_errnop = statp->res_h_errno; 361225edeacSHajimu UMEMOTO return (NS_RETURN); 3621363f04cSPaul Traina } 363d3ac2b30SHajimu UMEMOTO *((struct netent **)rval) = nptr; 364d3ac2b30SHajimu UMEMOTO return (NS_SUCCESS); 365d3ac2b30SHajimu UMEMOTO } 366d3ac2b30SHajimu UMEMOTO *h_errnop = statp->res_h_errno; 367d3ac2b30SHajimu UMEMOTO return (NS_NOTFOUND); 3684faad310SPeter Wemm } 3691363f04cSPaul Traina 370248aee62SJacques Vidrine int 371248aee62SJacques Vidrine _dns_getnetbyname(void *rval, void *cb_data, va_list ap) 3721363f04cSPaul Traina { 373248aee62SJacques Vidrine const char *net; 374d3ac2b30SHajimu UMEMOTO char *buffer; 375d3ac2b30SHajimu UMEMOTO size_t buflen; 376d3ac2b30SHajimu UMEMOTO int *errnop, *h_errnop; 377d3ac2b30SHajimu UMEMOTO struct netent *nptr, ne; 378a2a77501SHajimu UMEMOTO struct netent_data *ned; 379a2a77501SHajimu UMEMOTO int anslen, error; 380a52b6b83SHajimu UMEMOTO querybuf *buf; 3811363f04cSPaul Traina char qbuf[MAXDNAME]; 3825342d17fSHajimu UMEMOTO res_state statp; 3831363f04cSPaul Traina 384248aee62SJacques Vidrine net = va_arg(ap, const char *); 385d3ac2b30SHajimu UMEMOTO nptr = va_arg(ap, struct netent *); 386d3ac2b30SHajimu UMEMOTO buffer = va_arg(ap, char *); 387d3ac2b30SHajimu UMEMOTO buflen = va_arg(ap, size_t); 388d3ac2b30SHajimu UMEMOTO errnop = va_arg(ap, int *); 389d3ac2b30SHajimu UMEMOTO h_errnop = va_arg(ap, int *); 390248aee62SJacques Vidrine 3915342d17fSHajimu UMEMOTO statp = __res_state(); 3925342d17fSHajimu UMEMOTO if ((statp->options & RES_INIT) == 0 && res_ninit(statp) == -1) { 3935342d17fSHajimu UMEMOTO RES_SET_H_ERRNO(statp, NETDB_INTERNAL); 394d3ac2b30SHajimu UMEMOTO *h_errnop = statp->res_h_errno; 395d3ac2b30SHajimu UMEMOTO return (NS_UNAVAIL); 396d3ac2b30SHajimu UMEMOTO } 397d3ac2b30SHajimu UMEMOTO if ((ned = __netent_data_init()) == NULL) { 398d3ac2b30SHajimu UMEMOTO RES_SET_H_ERRNO(statp, NETDB_INTERNAL); 399d3ac2b30SHajimu UMEMOTO *h_errnop = statp->res_h_errno; 400d3ac2b30SHajimu UMEMOTO return (NS_UNAVAIL); 4014faad310SPeter Wemm } 402a52b6b83SHajimu UMEMOTO if ((buf = malloc(sizeof(*buf))) == NULL) { 4035342d17fSHajimu UMEMOTO RES_SET_H_ERRNO(statp, NETDB_INTERNAL); 404d3ac2b30SHajimu UMEMOTO *h_errnop = statp->res_h_errno; 405d3ac2b30SHajimu UMEMOTO return (NS_NOTFOUND); 406a52b6b83SHajimu UMEMOTO } 407d3ac2b30SHajimu UMEMOTO 408d3ac2b30SHajimu UMEMOTO *((struct netent **)rval) = NULL; 409d3ac2b30SHajimu UMEMOTO 4103c8e19e1SWarner Losh strncpy(qbuf, net, sizeof(qbuf) - 1); 4113c8e19e1SWarner Losh qbuf[sizeof(qbuf) - 1] = '\0'; 4125342d17fSHajimu UMEMOTO anslen = res_nsearch(statp, qbuf, C_IN, T_PTR, (u_char *)buf, 4135342d17fSHajimu UMEMOTO sizeof(*buf)); 4141363f04cSPaul Traina if (anslen < 0) { 415a52b6b83SHajimu UMEMOTO free(buf); 4164faad310SPeter Wemm #ifdef DEBUG 4175342d17fSHajimu UMEMOTO if (statp->options & RES_DEBUG) 4185342d17fSHajimu UMEMOTO printf("res_nsearch failed\n"); 41954384cf3SJacques Vidrine #endif 420d3ac2b30SHajimu UMEMOTO return (NS_UNAVAIL); 421a52b6b83SHajimu UMEMOTO } else if (anslen > sizeof(*buf)) { 422a52b6b83SHajimu UMEMOTO free(buf); 42354384cf3SJacques Vidrine #ifdef DEBUG 4245342d17fSHajimu UMEMOTO if (statp->options & RES_DEBUG) 4257922d4cfSJacques Vidrine printf("res_search static buffer too small\n"); 4264faad310SPeter Wemm #endif 427d3ac2b30SHajimu UMEMOTO return (NS_UNAVAIL); 4281363f04cSPaul Traina } 429d3ac2b30SHajimu UMEMOTO error = getnetanswer(buf, anslen, BYNAME, &ne, ned, statp); 430a52b6b83SHajimu UMEMOTO free(buf); 431d3ac2b30SHajimu UMEMOTO if (error != 0) { 432d3ac2b30SHajimu UMEMOTO *h_errnop = statp->res_h_errno; 433d3ac2b30SHajimu UMEMOTO return (NS_NOTFOUND); 434d3ac2b30SHajimu UMEMOTO } 435d3ac2b30SHajimu UMEMOTO if (__copy_netent(&ne, nptr, buffer, buflen) != 0) { 436225edeacSHajimu UMEMOTO *errnop = errno; 437225edeacSHajimu UMEMOTO RES_SET_H_ERRNO(statp, NETDB_INTERNAL); 438d3ac2b30SHajimu UMEMOTO *h_errnop = statp->res_h_errno; 439225edeacSHajimu UMEMOTO return (NS_RETURN); 440d3ac2b30SHajimu UMEMOTO } 441d3ac2b30SHajimu UMEMOTO *((struct netent **)rval) = nptr; 442d3ac2b30SHajimu UMEMOTO return (NS_SUCCESS); 4431363f04cSPaul Traina } 4441363f04cSPaul Traina 4451363f04cSPaul Traina void 446d3ac2b30SHajimu UMEMOTO _setnetdnsent(int stayopen) 4471363f04cSPaul Traina { 4485342d17fSHajimu UMEMOTO res_state statp; 4495342d17fSHajimu UMEMOTO 4505342d17fSHajimu UMEMOTO statp = __res_state(); 4515342d17fSHajimu UMEMOTO if ((statp->options & RES_INIT) == 0 && res_ninit(statp) == -1) 4525342d17fSHajimu UMEMOTO return; 4531363f04cSPaul Traina if (stayopen) 4545342d17fSHajimu UMEMOTO statp->options |= RES_STAYOPEN | RES_USEVC; 4551363f04cSPaul Traina } 4561363f04cSPaul Traina 4571363f04cSPaul Traina void 458*626c9d74SCraig Rodrigues _endnetdnsent(void) 4591363f04cSPaul Traina { 4605342d17fSHajimu UMEMOTO res_state statp; 4615342d17fSHajimu UMEMOTO 4625342d17fSHajimu UMEMOTO statp = __res_state(); 4635342d17fSHajimu UMEMOTO statp->options &= ~(RES_STAYOPEN | RES_USEVC); 4645342d17fSHajimu UMEMOTO res_nclose(statp); 4651363f04cSPaul Traina } 466