1*8a16b7a1SPedro F. Giffuni /*-
2*8a16b7a1SPedro F. Giffuni * SPDX-License-Identifier: BSD-3-Clause
3*8a16b7a1SPedro F. Giffuni *
41363f04cSPaul Traina * Copyright (c) 1983, 1993
51363f04cSPaul Traina * The Regents of the University of California. All rights reserved.
61363f04cSPaul Traina *
71363f04cSPaul Traina * Redistribution and use in source and binary forms, with or without
81363f04cSPaul Traina * modification, are permitted provided that the following conditions
91363f04cSPaul Traina * are met:
101363f04cSPaul Traina * 1. Redistributions of source code must retain the above copyright
111363f04cSPaul Traina * notice, this list of conditions and the following disclaimer.
121363f04cSPaul Traina * 2. Redistributions in binary form must reproduce the above copyright
131363f04cSPaul Traina * notice, this list of conditions and the following disclaimer in the
141363f04cSPaul Traina * documentation and/or other materials provided with the distribution.
15fbbd9655SWarner Losh * 3. Neither the name of the University nor the names of its contributors
161363f04cSPaul Traina * may be used to endorse or promote products derived from this software
171363f04cSPaul Traina * without specific prior written permission.
181363f04cSPaul Traina *
191363f04cSPaul Traina * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
201363f04cSPaul Traina * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
211363f04cSPaul Traina * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
221363f04cSPaul Traina * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
231363f04cSPaul Traina * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
241363f04cSPaul Traina * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
251363f04cSPaul Traina * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
261363f04cSPaul Traina * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
271363f04cSPaul Traina * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
281363f04cSPaul Traina * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
291363f04cSPaul Traina * SUCH DAMAGE.
301363f04cSPaul Traina */
311363f04cSPaul Traina
324faad310SPeter Wemm /* Portions Copyright (c) 1993 Carlos Leandro and Rui Salgueiro
334faad310SPeter Wemm * Dep. Matematica Universidade de Coimbra, Portugal, Europe
344faad310SPeter Wemm *
354faad310SPeter Wemm * Permission to use, copy, modify, and distribute this software for any
364faad310SPeter Wemm * purpose with or without fee is hereby granted, provided that the above
374faad310SPeter Wemm * copyright notice and this permission notice appear in all copies.
384faad310SPeter Wemm *
394faad310SPeter Wemm * from getnetent.c 1.1 (Coimbra) 93/06/02
404faad310SPeter Wemm */
414faad310SPeter Wemm
421363f04cSPaul Traina #include <sys/types.h>
431363f04cSPaul Traina #include <sys/socket.h>
441363f04cSPaul Traina #include <netinet/in.h>
451363f04cSPaul Traina #include <arpa/inet.h>
464faad310SPeter Wemm #include <arpa/nameser.h>
47225edeacSHajimu UMEMOTO #include <errno.h>
481363f04cSPaul Traina #include <netdb.h>
495342d17fSHajimu UMEMOTO #include <resolv.h>
501363f04cSPaul Traina #include <stdio.h>
511363f04cSPaul Traina #include <string.h>
52248aee62SJacques Vidrine #include <stdarg.h>
53248aee62SJacques Vidrine #include <nsswitch.h>
54a2a77501SHajimu UMEMOTO #include "netdb_private.h"
551363f04cSPaul Traina
561363f04cSPaul Traina void
_setnethtent(int f,struct netent_data * ned)57a2a77501SHajimu UMEMOTO _setnethtent(int f, struct netent_data *ned)
581363f04cSPaul Traina {
594faad310SPeter Wemm
60a2a77501SHajimu UMEMOTO if (ned->netf == NULL)
61a93705b0SJilles Tjoelker ned->netf = fopen(_PATH_NETWORKS, "re");
621363f04cSPaul Traina else
63a2a77501SHajimu UMEMOTO rewind(ned->netf);
64a2a77501SHajimu UMEMOTO ned->stayopen |= f;
651363f04cSPaul Traina }
661363f04cSPaul Traina
671363f04cSPaul Traina void
_endnethtent(struct netent_data * ned)68a2a77501SHajimu UMEMOTO _endnethtent(struct netent_data *ned)
691363f04cSPaul Traina {
704faad310SPeter Wemm
71a2a77501SHajimu UMEMOTO if (ned->netf) {
72a2a77501SHajimu UMEMOTO fclose(ned->netf);
73a2a77501SHajimu UMEMOTO ned->netf = NULL;
741363f04cSPaul Traina }
75a2a77501SHajimu UMEMOTO ned->stayopen = 0;
761363f04cSPaul Traina }
771363f04cSPaul Traina
78d3ac2b30SHajimu UMEMOTO static int
getnetent_p(struct netent * ne,struct netent_data * ned)79d3ac2b30SHajimu UMEMOTO getnetent_p(struct netent *ne, struct netent_data *ned)
801363f04cSPaul Traina {
81a2a77501SHajimu UMEMOTO char *p, *bp, *ep;
828fb3f3f6SDavid E. O'Brien char *cp, **q;
83a2a77501SHajimu UMEMOTO int len;
84a2a77501SHajimu UMEMOTO char line[BUFSIZ + 1];
851363f04cSPaul Traina
86a2a77501SHajimu UMEMOTO if (ned->netf == NULL &&
87a93705b0SJilles Tjoelker (ned->netf = fopen(_PATH_NETWORKS, "re")) == NULL)
88d3ac2b30SHajimu UMEMOTO return (-1);
891363f04cSPaul Traina again:
90a2a77501SHajimu UMEMOTO p = fgets(line, sizeof line, ned->netf);
911363f04cSPaul Traina if (p == NULL)
92d3ac2b30SHajimu UMEMOTO return (-1);
931363f04cSPaul Traina if (*p == '#')
941363f04cSPaul Traina goto again;
951363f04cSPaul Traina cp = strpbrk(p, "#\n");
967b6cc404SMaxim Sobolev if (cp != NULL)
971363f04cSPaul Traina *cp = '\0';
98a2a77501SHajimu UMEMOTO bp = ned->netbuf;
99a2a77501SHajimu UMEMOTO ep = ned->netbuf + sizeof ned->netbuf;
100a2a77501SHajimu UMEMOTO ne->n_name = bp;
1011363f04cSPaul Traina cp = strpbrk(p, " \t");
1021363f04cSPaul Traina if (cp == NULL)
1031363f04cSPaul Traina goto again;
1041363f04cSPaul Traina *cp++ = '\0';
105a2a77501SHajimu UMEMOTO len = strlen(p) + 1;
106a2a77501SHajimu UMEMOTO if (ep - bp < len) {
1075342d17fSHajimu UMEMOTO RES_SET_H_ERRNO(__res_state(), NO_RECOVERY);
108d3ac2b30SHajimu UMEMOTO return (-1);
109a2a77501SHajimu UMEMOTO }
110a2a77501SHajimu UMEMOTO strlcpy(bp, p, ep - bp);
111a2a77501SHajimu UMEMOTO bp += len;
1121363f04cSPaul Traina while (*cp == ' ' || *cp == '\t')
1131363f04cSPaul Traina cp++;
1141363f04cSPaul Traina p = strpbrk(cp, " \t");
1151363f04cSPaul Traina if (p != NULL)
1161363f04cSPaul Traina *p++ = '\0';
117a2a77501SHajimu UMEMOTO ne->n_net = inet_network(cp);
118a2a77501SHajimu UMEMOTO ne->n_addrtype = AF_INET;
119a2a77501SHajimu UMEMOTO q = ne->n_aliases = ned->net_aliases;
12071d0cbb6SHajimu UMEMOTO if (p != NULL) {
1211363f04cSPaul Traina cp = p;
1221363f04cSPaul Traina while (cp && *cp) {
1231363f04cSPaul Traina if (*cp == ' ' || *cp == '\t') {
1241363f04cSPaul Traina cp++;
1251363f04cSPaul Traina continue;
1261363f04cSPaul Traina }
127a2a77501SHajimu UMEMOTO if (q >= &ned->net_aliases[_MAXALIASES - 1])
128a2a77501SHajimu UMEMOTO break;
129a2a77501SHajimu UMEMOTO p = strpbrk(cp, " \t");
130a2a77501SHajimu UMEMOTO if (p != NULL)
131a2a77501SHajimu UMEMOTO *p++ = '\0';
132a2a77501SHajimu UMEMOTO len = strlen(cp) + 1;
133a2a77501SHajimu UMEMOTO if (ep - bp < len)
134a2a77501SHajimu UMEMOTO break;
135a2a77501SHajimu UMEMOTO strlcpy(bp, cp, ep - bp);
136a2a77501SHajimu UMEMOTO *q++ = bp;
137a2a77501SHajimu UMEMOTO bp += len;
138a2a77501SHajimu UMEMOTO cp = p;
1391363f04cSPaul Traina }
14071d0cbb6SHajimu UMEMOTO }
1411363f04cSPaul Traina *q = NULL;
142d3ac2b30SHajimu UMEMOTO return (0);
143d3ac2b30SHajimu UMEMOTO }
144d3ac2b30SHajimu UMEMOTO
145d3ac2b30SHajimu UMEMOTO int
getnetent_r(struct netent * nptr,char * buffer,size_t buflen,struct netent ** result,int * h_errnop)146d3ac2b30SHajimu UMEMOTO getnetent_r(struct netent *nptr, char *buffer, size_t buflen,
147d3ac2b30SHajimu UMEMOTO struct netent **result, int *h_errnop)
148d3ac2b30SHajimu UMEMOTO {
149d3ac2b30SHajimu UMEMOTO struct netent_data *ned;
150d3ac2b30SHajimu UMEMOTO struct netent ne;
151d3ac2b30SHajimu UMEMOTO res_state statp;
152d3ac2b30SHajimu UMEMOTO
153d3ac2b30SHajimu UMEMOTO statp = __res_state();
154d3ac2b30SHajimu UMEMOTO if ((ned = __netent_data_init()) == NULL) {
155d3ac2b30SHajimu UMEMOTO RES_SET_H_ERRNO(statp, NETDB_INTERNAL);
156d3ac2b30SHajimu UMEMOTO *h_errnop = statp->res_h_errno;
157d3ac2b30SHajimu UMEMOTO return (-1);
158d3ac2b30SHajimu UMEMOTO }
159d3ac2b30SHajimu UMEMOTO if (getnetent_p(&ne, ned) != 0)
160d3ac2b30SHajimu UMEMOTO return (-1);
161225edeacSHajimu UMEMOTO if (__copy_netent(&ne, nptr, buffer, buflen) != 0) {
162225edeacSHajimu UMEMOTO RES_SET_H_ERRNO(statp, NETDB_INTERNAL);
163225edeacSHajimu UMEMOTO *h_errnop = statp->res_h_errno;
164225edeacSHajimu UMEMOTO return ((errno != 0) ? errno : -1);
165225edeacSHajimu UMEMOTO }
166d3ac2b30SHajimu UMEMOTO *result = nptr;
167d3ac2b30SHajimu UMEMOTO return (0);
168a2a77501SHajimu UMEMOTO }
169a2a77501SHajimu UMEMOTO
170a2a77501SHajimu UMEMOTO struct netent *
getnetent(void)171a2a77501SHajimu UMEMOTO getnetent(void)
172a2a77501SHajimu UMEMOTO {
173a2a77501SHajimu UMEMOTO struct netdata *nd;
174d3ac2b30SHajimu UMEMOTO struct netent *rval;
175d3ac2b30SHajimu UMEMOTO int ret_h_errno;
176a2a77501SHajimu UMEMOTO
177a2a77501SHajimu UMEMOTO if ((nd = __netdata_init()) == NULL)
178d3ac2b30SHajimu UMEMOTO return (NULL);
179d3ac2b30SHajimu UMEMOTO if (getnetent_r(&nd->net, nd->data, sizeof(nd->data), &rval,
180d3ac2b30SHajimu UMEMOTO &ret_h_errno) != 0)
181d3ac2b30SHajimu UMEMOTO return (NULL);
182d3ac2b30SHajimu UMEMOTO return (rval);
1831363f04cSPaul Traina }
1841363f04cSPaul Traina
185248aee62SJacques Vidrine int
_ht_getnetbyname(void * rval,void * cb_data,va_list ap)186248aee62SJacques Vidrine _ht_getnetbyname(void *rval, void *cb_data, va_list ap)
1871363f04cSPaul Traina {
188248aee62SJacques Vidrine const char *name;
189d3ac2b30SHajimu UMEMOTO char *buffer;
190d3ac2b30SHajimu UMEMOTO size_t buflen;
191d3ac2b30SHajimu UMEMOTO int *errnop, *h_errnop;
192d3ac2b30SHajimu UMEMOTO struct netent *nptr, ne;
193a2a77501SHajimu UMEMOTO struct netent_data *ned;
1948fb3f3f6SDavid E. O'Brien char **cp;
195d3ac2b30SHajimu UMEMOTO res_state statp;
196a2a77501SHajimu UMEMOTO int error;
1971363f04cSPaul Traina
198248aee62SJacques Vidrine name = va_arg(ap, const char *);
199d3ac2b30SHajimu UMEMOTO nptr = va_arg(ap, struct netent *);
200d3ac2b30SHajimu UMEMOTO buffer = va_arg(ap, char *);
201d3ac2b30SHajimu UMEMOTO buflen = va_arg(ap, size_t);
202d3ac2b30SHajimu UMEMOTO errnop = va_arg(ap, int *);
203d3ac2b30SHajimu UMEMOTO h_errnop = va_arg(ap, int *);
204248aee62SJacques Vidrine
205d3ac2b30SHajimu UMEMOTO statp = __res_state();
206d3ac2b30SHajimu UMEMOTO if ((ned = __netent_data_init()) == NULL) {
207d3ac2b30SHajimu UMEMOTO RES_SET_H_ERRNO(statp, NETDB_INTERNAL);
208d3ac2b30SHajimu UMEMOTO *h_errnop = statp->res_h_errno;
209d3ac2b30SHajimu UMEMOTO return (NS_UNAVAIL);
210d3ac2b30SHajimu UMEMOTO }
211d3ac2b30SHajimu UMEMOTO
212d3ac2b30SHajimu UMEMOTO _setnethtent(ned->stayopen, ned);
213b7e992daSEnji Cooper while ((error = getnetent_p(&ne, ned)) == 0) {
214d3ac2b30SHajimu UMEMOTO if (strcasecmp(ne.n_name, name) == 0)
2151363f04cSPaul Traina break;
216b7e992daSEnji Cooper for (cp = ne.n_aliases; *cp != 0; cp++)
2171363f04cSPaul Traina if (strcasecmp(*cp, name) == 0)
2181363f04cSPaul Traina goto found;
2191363f04cSPaul Traina }
2201363f04cSPaul Traina found:
221a2a77501SHajimu UMEMOTO if (!ned->stayopen)
222d3ac2b30SHajimu UMEMOTO _endnethtent(ned);
223d3ac2b30SHajimu UMEMOTO if (error != 0) {
224d3ac2b30SHajimu UMEMOTO *h_errnop = statp->res_h_errno;
225d3ac2b30SHajimu UMEMOTO return (NS_NOTFOUND);
226d3ac2b30SHajimu UMEMOTO }
227d3ac2b30SHajimu UMEMOTO if (__copy_netent(&ne, nptr, buffer, buflen) != 0) {
228225edeacSHajimu UMEMOTO *errnop = errno;
229225edeacSHajimu UMEMOTO RES_SET_H_ERRNO(statp, NETDB_INTERNAL);
230d3ac2b30SHajimu UMEMOTO *h_errnop = statp->res_h_errno;
231225edeacSHajimu UMEMOTO return (NS_RETURN);
232d3ac2b30SHajimu UMEMOTO }
233d3ac2b30SHajimu UMEMOTO *((struct netent **)rval) = nptr;
234d3ac2b30SHajimu UMEMOTO return (NS_SUCCESS);
2351363f04cSPaul Traina }
2361363f04cSPaul Traina
237248aee62SJacques Vidrine int
_ht_getnetbyaddr(void * rval,void * cb_data,va_list ap)238248aee62SJacques Vidrine _ht_getnetbyaddr(void *rval, void *cb_data, va_list ap)
2391363f04cSPaul Traina {
240036ae3ddSHajimu UMEMOTO uint32_t net;
241248aee62SJacques Vidrine int type;
242d3ac2b30SHajimu UMEMOTO char *buffer;
243d3ac2b30SHajimu UMEMOTO size_t buflen;
244d3ac2b30SHajimu UMEMOTO int *errnop, *h_errnop;
245d3ac2b30SHajimu UMEMOTO struct netent *nptr, ne;
246a2a77501SHajimu UMEMOTO struct netent_data *ned;
247d3ac2b30SHajimu UMEMOTO res_state statp;
248a2a77501SHajimu UMEMOTO int error;
2491363f04cSPaul Traina
250036ae3ddSHajimu UMEMOTO net = va_arg(ap, uint32_t);
251248aee62SJacques Vidrine type = va_arg(ap, int);
252d3ac2b30SHajimu UMEMOTO nptr = va_arg(ap, struct netent *);
253d3ac2b30SHajimu UMEMOTO buffer = va_arg(ap, char *);
254d3ac2b30SHajimu UMEMOTO buflen = va_arg(ap, size_t);
255d3ac2b30SHajimu UMEMOTO errnop = va_arg(ap, int *);
256d3ac2b30SHajimu UMEMOTO h_errnop = va_arg(ap, int *);
257248aee62SJacques Vidrine
258d3ac2b30SHajimu UMEMOTO statp = __res_state();
259d3ac2b30SHajimu UMEMOTO if ((ned = __netent_data_init()) == NULL) {
260d3ac2b30SHajimu UMEMOTO RES_SET_H_ERRNO(statp, NETDB_INTERNAL);
261d3ac2b30SHajimu UMEMOTO *h_errnop = statp->res_h_errno;
262d3ac2b30SHajimu UMEMOTO return (NS_UNAVAIL);
263d3ac2b30SHajimu UMEMOTO }
264d3ac2b30SHajimu UMEMOTO
265d3ac2b30SHajimu UMEMOTO _setnethtent(ned->stayopen, ned);
266d3ac2b30SHajimu UMEMOTO while ((error = getnetent_p(&ne, ned)) == 0)
267d3ac2b30SHajimu UMEMOTO if (ne.n_addrtype == type && ne.n_net == net)
2681363f04cSPaul Traina break;
269a2a77501SHajimu UMEMOTO if (!ned->stayopen)
270d3ac2b30SHajimu UMEMOTO _endnethtent(ned);
271d3ac2b30SHajimu UMEMOTO if (error != 0) {
272d3ac2b30SHajimu UMEMOTO *h_errnop = statp->res_h_errno;
273d3ac2b30SHajimu UMEMOTO return (NS_NOTFOUND);
274d3ac2b30SHajimu UMEMOTO }
275d3ac2b30SHajimu UMEMOTO if (__copy_netent(&ne, nptr, buffer, buflen) != 0) {
276225edeacSHajimu UMEMOTO *errnop = errno;
277225edeacSHajimu UMEMOTO RES_SET_H_ERRNO(statp, NETDB_INTERNAL);
278d3ac2b30SHajimu UMEMOTO *h_errnop = statp->res_h_errno;
279225edeacSHajimu UMEMOTO return (NS_RETURN);
280d3ac2b30SHajimu UMEMOTO }
281d3ac2b30SHajimu UMEMOTO *((struct netent **)rval) = nptr;
282d3ac2b30SHajimu UMEMOTO return (NS_SUCCESS);
2831363f04cSPaul Traina }
284