1 /* Copyright (C) 1996-2000, 2001, 2002 Free Software Foundation, Inc.
2 This file is part of the GNU C Library.
3 Contributed by Thorsten Kukuk <kukuk@suse.de>, 1996.
5 The GNU C Library is free software; you can redistribute it and/or
6 modify it under the terms of the GNU Lesser General Public
7 License as published by the Free Software Foundation; either
8 version 2.1 of the License, or (at your option) any later version.
10 The GNU C Library is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 Lesser General Public License for more details.
15 You should have received a copy of the GNU Lesser General Public
16 License along with the GNU C Library; if not, write to the Free
17 Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
24 #include <bits/libc-lock.h>
25 #include <rpcsvc/yp.h>
26 #include <rpcsvc/ypclnt.h>
27 #include <netinet/ether.h>
28 #include <netinet/if_ether.h>
32 /* Protect global state against multiple changers */
33 __libc_lock_define_initialized (static, lock
)
35 /* Get the declaration of the parser function. */
36 #define ENTNAME etherent
37 #define STRUCTURE etherent
39 #include <nss/nss_files/files-parse.c>
44 struct response
*next
;
47 static struct response
*start
;
48 static struct response
*next
;
51 saveit (int instatus
, char *inkey
, int inkeylen
, char *inval
,
52 int invallen
, char *indata
)
54 if (instatus
!= YP_TRUE
)
57 if (inkey
&& inkeylen
> 0 && inval
&& invallen
> 0)
61 start
= malloc (sizeof (struct response
));
68 next
->next
= malloc (sizeof (struct response
));
69 if (next
->next
== NULL
)
74 next
->val
= malloc (invallen
+ 1);
75 if (next
->val
== NULL
)
77 strncpy (next
->val
, inval
, invallen
);
78 next
->val
[invallen
] = '\0';
84 static enum nss_status
85 internal_nis_setetherent (void)
88 struct ypall_callback ypcb
;
89 enum nss_status status
;
91 yp_get_default_domain (&domainname
);
95 if (start
->val
!= NULL
)
103 ypcb
.foreach
= saveit
;
105 status
= yperr2nss (yp_all (domainname
, "ethers.byname", &ypcb
));
112 _nss_nis_setetherent (int stayopen
)
114 enum nss_status result
;
116 __libc_lock_lock (lock
);
118 result
= internal_nis_setetherent ();
120 __libc_lock_unlock (lock
);
126 _nss_nis_endetherent (void)
128 __libc_lock_lock (lock
);
130 while (start
!= NULL
)
132 if (start
->val
!= NULL
)
141 __libc_lock_unlock (lock
);
143 return NSS_STATUS_SUCCESS
;
146 static enum nss_status
147 internal_nis_getetherent_r (struct etherent
*eth
, char *buffer
, size_t buflen
,
150 struct parser_data
*data
= (void *) buffer
;
154 internal_nis_setetherent ();
156 /* Get the next entry until we found a correct one. */
162 return NSS_STATUS_NOTFOUND
;
164 p
= strncpy (buffer
, next
->val
, buflen
);
169 parse_res
= _nss_files_parse_etherent (p
, eth
, data
, buflen
, errnop
);
171 return NSS_STATUS_TRYAGAIN
;
176 return NSS_STATUS_SUCCESS
;
180 _nss_nis_getetherent_r (struct etherent
*result
, char *buffer
, size_t buflen
,
185 __libc_lock_lock (lock
);
187 status
= internal_nis_getetherent_r (result
, buffer
, buflen
, errnop
);
189 __libc_lock_unlock (lock
);
195 _nss_nis_gethostton_r (const char *name
, struct etherent
*eth
,
196 char *buffer
, size_t buflen
, int *errnop
)
198 struct parser_data
*data
= (void *) buffer
;
199 enum nss_status retval
;
200 char *domain
, *result
, *p
;
206 return NSS_STATUS_UNAVAIL
;
209 if (yp_get_default_domain (&domain
))
210 return NSS_STATUS_UNAVAIL
;
212 retval
= yperr2nss (yp_match (domain
, "ethers.byname", name
,
213 strlen (name
), &result
, &len
));
215 if (retval
!= NSS_STATUS_SUCCESS
)
217 if (retval
== NSS_STATUS_TRYAGAIN
)
222 if ((size_t) (len
+ 1) > buflen
)
226 return NSS_STATUS_TRYAGAIN
;
229 p
= strncpy (buffer
, result
, len
);
235 parse_res
= _nss_files_parse_etherent (p
, eth
, data
, buflen
, errnop
);
239 return NSS_STATUS_TRYAGAIN
;
241 return NSS_STATUS_NOTFOUND
;
243 return NSS_STATUS_SUCCESS
;
247 _nss_nis_getntohost_r (const struct ether_addr
*addr
, struct etherent
*eth
,
248 char *buffer
, size_t buflen
, int *errnop
)
250 struct parser_data
*data
= (void *) buffer
;
251 enum nss_status retval
;
252 char *domain
, *result
, *p
;
253 int len
, nlen
, parse_res
;
259 return NSS_STATUS_UNAVAIL
;
262 if (yp_get_default_domain (&domain
))
263 return NSS_STATUS_UNAVAIL
;
265 nlen
= sprintf (buf
, "%x:%x:%x:%x:%x:%x",
266 (int) addr
->ether_addr_octet
[0],
267 (int) addr
->ether_addr_octet
[1],
268 (int) addr
->ether_addr_octet
[2],
269 (int) addr
->ether_addr_octet
[3],
270 (int) addr
->ether_addr_octet
[4],
271 (int) addr
->ether_addr_octet
[5]);
273 retval
= yperr2nss (yp_match (domain
, "ethers.byaddr", buf
,
274 nlen
, &result
, &len
));
276 if (retval
!= NSS_STATUS_SUCCESS
)
278 if (retval
== NSS_STATUS_TRYAGAIN
)
283 if ((size_t) (len
+ 1) > buflen
)
287 return NSS_STATUS_TRYAGAIN
;
290 p
= strncpy (buffer
, result
, len
);
296 parse_res
= _nss_files_parse_etherent (p
, eth
, data
, buflen
, errnop
);
300 return NSS_STATUS_TRYAGAIN
;
302 return NSS_STATUS_NOTFOUND
;
304 return NSS_STATUS_SUCCESS
;