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); 199d3ac2b30SHajimu 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; 223d3ac2b30SHajimu 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; 246d3ac2b30SHajimu 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; 253d3ac2b30SHajimu 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++; 260d3ac2b30SHajimu UMEMOTO return (0); 2611363f04cSPaul Traina } 2625342d17fSHajimu UMEMOTO RES_SET_H_ERRNO(statp, TRY_AGAIN); 263d3ac2b30SHajimu 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; 271d3ac2b30SHajimu UMEMOTO char *buffer; 272d3ac2b30SHajimu UMEMOTO size_t buflen; 273d3ac2b30SHajimu UMEMOTO int *errnop, *h_errnop; 274d3ac2b30SHajimu UMEMOTO struct netent *nptr, ne; 275a2a77501SHajimu UMEMOTO struct netent_data *ned; 2761363f04cSPaul Traina unsigned int netbr[4]; 277a2a77501SHajimu UMEMOTO int nn, anslen, error; 278a52b6b83SHajimu UMEMOTO querybuf *buf; 2791363f04cSPaul Traina char qbuf[MAXDNAME]; 280036ae3ddSHajimu UMEMOTO uint32_t net2; 2815342d17fSHajimu UMEMOTO res_state statp; 2821363f04cSPaul Traina 283036ae3ddSHajimu UMEMOTO net = va_arg(ap, uint32_t); 284248aee62SJacques Vidrine net_type = va_arg(ap, int); 285d3ac2b30SHajimu UMEMOTO nptr = va_arg(ap, struct netent *); 286d3ac2b30SHajimu UMEMOTO buffer = va_arg(ap, char *); 287d3ac2b30SHajimu UMEMOTO buflen = va_arg(ap, size_t); 288d3ac2b30SHajimu UMEMOTO errnop = va_arg(ap, int *); 289d3ac2b30SHajimu UMEMOTO h_errnop = va_arg(ap, int *); 2901363f04cSPaul Traina 2915342d17fSHajimu UMEMOTO statp = __res_state(); 2925342d17fSHajimu UMEMOTO if ((statp->options & RES_INIT) == 0 && res_ninit(statp) == -1) { 2935342d17fSHajimu UMEMOTO RES_SET_H_ERRNO(statp, NETDB_INTERNAL); 294d3ac2b30SHajimu UMEMOTO *h_errnop = statp->res_h_errno; 295d3ac2b30SHajimu UMEMOTO return (NS_UNAVAIL); 296d3ac2b30SHajimu UMEMOTO } 297d3ac2b30SHajimu UMEMOTO 298d3ac2b30SHajimu UMEMOTO if ((ned = __netent_data_init()) == NULL) { 299d3ac2b30SHajimu UMEMOTO RES_SET_H_ERRNO(statp, NETDB_INTERNAL); 300d3ac2b30SHajimu UMEMOTO *h_errnop = statp->res_h_errno; 301d3ac2b30SHajimu UMEMOTO return (NS_UNAVAIL); 302d3ac2b30SHajimu UMEMOTO } 303d3ac2b30SHajimu UMEMOTO 304d3ac2b30SHajimu UMEMOTO *((struct netent **)rval) = NULL; 305d3ac2b30SHajimu UMEMOTO 306d3ac2b30SHajimu UMEMOTO if (net_type != AF_INET) { 307d3ac2b30SHajimu UMEMOTO RES_SET_H_ERRNO(statp, NETDB_INTERNAL); 308d3ac2b30SHajimu UMEMOTO *h_errnop = statp->res_h_errno; 309d3ac2b30SHajimu UMEMOTO return (NS_UNAVAIL); 3105342d17fSHajimu UMEMOTO } 3115342d17fSHajimu UMEMOTO 3124faad310SPeter Wemm for (nn = 4, net2 = net; net2; net2 >>= 8) 3131363f04cSPaul Traina netbr[--nn] = net2 & 0xff; 3141363f04cSPaul Traina switch (nn) { 3151363f04cSPaul Traina case 3: /* Class A */ 3164faad310SPeter Wemm sprintf(qbuf, "0.0.0.%u.in-addr.arpa", netbr[3]); 3171363f04cSPaul Traina break; 3181363f04cSPaul Traina case 2: /* Class B */ 3194faad310SPeter Wemm sprintf(qbuf, "0.0.%u.%u.in-addr.arpa", netbr[3], netbr[2]); 3201363f04cSPaul Traina break; 3211363f04cSPaul Traina case 1: /* Class C */ 3224faad310SPeter Wemm sprintf(qbuf, "0.%u.%u.%u.in-addr.arpa", netbr[3], netbr[2], 3234faad310SPeter Wemm netbr[1]); 3241363f04cSPaul Traina break; 3251363f04cSPaul Traina case 0: /* Class D - E */ 3264faad310SPeter Wemm sprintf(qbuf, "%u.%u.%u.%u.in-addr.arpa", netbr[3], netbr[2], 3274faad310SPeter Wemm netbr[1], netbr[0]); 3281363f04cSPaul Traina break; 3291363f04cSPaul Traina } 330a52b6b83SHajimu UMEMOTO if ((buf = malloc(sizeof(*buf))) == NULL) { 3315342d17fSHajimu UMEMOTO RES_SET_H_ERRNO(statp, NETDB_INTERNAL); 332d3ac2b30SHajimu UMEMOTO *h_errnop = statp->res_h_errno; 333d3ac2b30SHajimu UMEMOTO return (NS_NOTFOUND); 334a52b6b83SHajimu UMEMOTO } 3355342d17fSHajimu UMEMOTO anslen = res_nquery(statp, qbuf, C_IN, T_PTR, (u_char *)buf, 3365342d17fSHajimu UMEMOTO sizeof(*buf)); 3371363f04cSPaul Traina if (anslen < 0) { 338a52b6b83SHajimu UMEMOTO free(buf); 3394faad310SPeter Wemm #ifdef DEBUG 3405342d17fSHajimu UMEMOTO if (statp->options & RES_DEBUG) 3415342d17fSHajimu UMEMOTO printf("res_nsearch failed\n"); 34254384cf3SJacques Vidrine #endif 343d3ac2b30SHajimu UMEMOTO *h_errnop = statp->res_h_errno; 344d3ac2b30SHajimu UMEMOTO return (NS_UNAVAIL); 345a52b6b83SHajimu UMEMOTO } else if (anslen > sizeof(*buf)) { 346a52b6b83SHajimu UMEMOTO free(buf); 34754384cf3SJacques Vidrine #ifdef DEBUG 3485342d17fSHajimu UMEMOTO if (statp->options & RES_DEBUG) 3495342d17fSHajimu UMEMOTO printf("res_nsearch static buffer too small\n"); 3504faad310SPeter Wemm #endif 351d3ac2b30SHajimu UMEMOTO *h_errnop = statp->res_h_errno; 352d3ac2b30SHajimu UMEMOTO return (NS_UNAVAIL); 3531363f04cSPaul Traina } 354d3ac2b30SHajimu UMEMOTO error = getnetanswer(buf, anslen, BYADDR, &ne, ned, statp); 355a52b6b83SHajimu UMEMOTO free(buf); 356a2a77501SHajimu UMEMOTO if (error == 0) { 3571363f04cSPaul Traina /* Strip trailing zeros */ 358036ae3ddSHajimu UMEMOTO while ((net & 0xff) == 0 && net != 0) 359036ae3ddSHajimu UMEMOTO net >>= 8; 360d3ac2b30SHajimu UMEMOTO ne.n_net = net; 361d3ac2b30SHajimu UMEMOTO if (__copy_netent(&ne, nptr, buffer, buflen) != 0) { 362d3ac2b30SHajimu UMEMOTO *h_errnop = statp->res_h_errno; 363d3ac2b30SHajimu UMEMOTO return (NS_NOTFOUND); 3641363f04cSPaul Traina } 365d3ac2b30SHajimu UMEMOTO *((struct netent **)rval) = nptr; 366d3ac2b30SHajimu UMEMOTO return (NS_SUCCESS); 367d3ac2b30SHajimu UMEMOTO } 368d3ac2b30SHajimu UMEMOTO *h_errnop = statp->res_h_errno; 369d3ac2b30SHajimu UMEMOTO return (NS_NOTFOUND); 3704faad310SPeter Wemm } 3711363f04cSPaul Traina 372248aee62SJacques Vidrine int 373248aee62SJacques Vidrine _dns_getnetbyname(void *rval, void *cb_data, va_list ap) 3741363f04cSPaul Traina { 375248aee62SJacques Vidrine const char *net; 376d3ac2b30SHajimu UMEMOTO char *buffer; 377d3ac2b30SHajimu UMEMOTO size_t buflen; 378d3ac2b30SHajimu UMEMOTO int *errnop, *h_errnop; 379d3ac2b30SHajimu UMEMOTO struct netent *nptr, ne; 380a2a77501SHajimu UMEMOTO struct netent_data *ned; 381a2a77501SHajimu UMEMOTO int anslen, error; 382a52b6b83SHajimu UMEMOTO querybuf *buf; 3831363f04cSPaul Traina char qbuf[MAXDNAME]; 3845342d17fSHajimu UMEMOTO res_state statp; 3851363f04cSPaul Traina 386248aee62SJacques Vidrine net = va_arg(ap, const char *); 387d3ac2b30SHajimu UMEMOTO nptr = va_arg(ap, struct netent *); 388d3ac2b30SHajimu UMEMOTO buffer = va_arg(ap, char *); 389d3ac2b30SHajimu UMEMOTO buflen = va_arg(ap, size_t); 390d3ac2b30SHajimu UMEMOTO errnop = va_arg(ap, int *); 391d3ac2b30SHajimu UMEMOTO h_errnop = va_arg(ap, int *); 392248aee62SJacques Vidrine 3935342d17fSHajimu UMEMOTO statp = __res_state(); 3945342d17fSHajimu UMEMOTO if ((statp->options & RES_INIT) == 0 && res_ninit(statp) == -1) { 3955342d17fSHajimu UMEMOTO RES_SET_H_ERRNO(statp, NETDB_INTERNAL); 396d3ac2b30SHajimu UMEMOTO *h_errnop = statp->res_h_errno; 397d3ac2b30SHajimu UMEMOTO return (NS_UNAVAIL); 398d3ac2b30SHajimu UMEMOTO } 399d3ac2b30SHajimu UMEMOTO if ((ned = __netent_data_init()) == NULL) { 400d3ac2b30SHajimu UMEMOTO RES_SET_H_ERRNO(statp, NETDB_INTERNAL); 401d3ac2b30SHajimu UMEMOTO *h_errnop = statp->res_h_errno; 402d3ac2b30SHajimu UMEMOTO return (NS_UNAVAIL); 4034faad310SPeter Wemm } 404a52b6b83SHajimu UMEMOTO if ((buf = malloc(sizeof(*buf))) == NULL) { 4055342d17fSHajimu UMEMOTO RES_SET_H_ERRNO(statp, NETDB_INTERNAL); 406d3ac2b30SHajimu UMEMOTO *h_errnop = statp->res_h_errno; 407d3ac2b30SHajimu UMEMOTO return (NS_NOTFOUND); 408a52b6b83SHajimu UMEMOTO } 409d3ac2b30SHajimu UMEMOTO 410d3ac2b30SHajimu UMEMOTO *((struct netent **)rval) = NULL; 411d3ac2b30SHajimu UMEMOTO 4123c8e19e1SWarner Losh strncpy(qbuf, net, sizeof(qbuf) - 1); 4133c8e19e1SWarner Losh qbuf[sizeof(qbuf) - 1] = '\0'; 4145342d17fSHajimu UMEMOTO anslen = res_nsearch(statp, qbuf, C_IN, T_PTR, (u_char *)buf, 4155342d17fSHajimu UMEMOTO sizeof(*buf)); 4161363f04cSPaul Traina if (anslen < 0) { 417a52b6b83SHajimu UMEMOTO free(buf); 4184faad310SPeter Wemm #ifdef DEBUG 4195342d17fSHajimu UMEMOTO if (statp->options & RES_DEBUG) 4205342d17fSHajimu UMEMOTO printf("res_nsearch failed\n"); 42154384cf3SJacques Vidrine #endif 422d3ac2b30SHajimu UMEMOTO return (NS_UNAVAIL); 423a52b6b83SHajimu UMEMOTO } else if (anslen > sizeof(*buf)) { 424a52b6b83SHajimu UMEMOTO free(buf); 42554384cf3SJacques Vidrine #ifdef DEBUG 4265342d17fSHajimu UMEMOTO if (statp->options & RES_DEBUG) 4277922d4cfSJacques Vidrine printf("res_search static buffer too small\n"); 4284faad310SPeter Wemm #endif 429d3ac2b30SHajimu UMEMOTO return (NS_UNAVAIL); 4301363f04cSPaul Traina } 431d3ac2b30SHajimu UMEMOTO error = getnetanswer(buf, anslen, BYNAME, &ne, ned, statp); 432a52b6b83SHajimu UMEMOTO free(buf); 433d3ac2b30SHajimu UMEMOTO if (error != 0) { 434d3ac2b30SHajimu UMEMOTO *h_errnop = statp->res_h_errno; 435d3ac2b30SHajimu UMEMOTO return (NS_NOTFOUND); 436d3ac2b30SHajimu UMEMOTO } 437d3ac2b30SHajimu UMEMOTO if (__copy_netent(&ne, nptr, buffer, buflen) != 0) { 438d3ac2b30SHajimu UMEMOTO *h_errnop = statp->res_h_errno; 439d3ac2b30SHajimu UMEMOTO return (NS_NOTFOUND); 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 4581363f04cSPaul Traina _endnetdnsent() 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