]>
git.saurik.com Git - apple/libinfo.git/blob - nis.subproj/ypmatch_cache.c
2 * Copyright (c) 1999-2018 Apple Inc. All rights reserved.
4 * @APPLE_LICENSE_HEADER_START@
6 * Portions Copyright (c) 1999 Apple Computer, Inc. All Rights
7 * Reserved. This file contains Original Code and/or Modifications of
8 * Original Code as defined in and that are subject to the Apple Public
9 * Source License Version 1.1 (the "License"). You may not use this file
10 * except in compliance with the License. Please obtain a copy of the
11 * License at http://www.apple.com/publicsource and read it before using
14 * The Original Code and all software distributed under the License are
15 * distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, EITHER
16 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
17 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
18 * FITNESS FOR A PARTICULAR PURPOSE OR NON- INFRINGEMENT. Please see the
19 * License for the specific language governing rights and limitations
22 * @APPLE_LICENSE_HEADER_END@
25 * Copyright (c) 1992, 1993 Theo de Raadt <deraadt@theos.com>
26 * All rights reserved.
28 * Redistribution and use in source and binary forms, with or without
29 * modification, are permitted provided that the following conditions
31 * 1. Redistributions of source code must retain the above copyright
32 * notice, this list of conditions and the following disclaimer.
33 * 2. Redistributions in binary form must reproduce the above copyright
34 * notice, this list of conditions and the following disclaimer in the
35 * documentation and/or other materials provided with the distribution.
36 * 3. All advertising materials mentioning features or use of this software
37 * must display the following acknowledgement:
38 * This product includes software developed by Theo de Raadt.
39 * 4. The name of the author may not be used to endorse or promote products
40 * derived from this software without specific prior written permission.
42 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS
43 * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
44 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
45 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
46 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
47 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
48 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
49 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
50 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
51 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
55 #if defined(LIBC_SCCS) && !defined(lint)
56 static char *rcsid
= "$OpenBSD: ypmatch_cache.c,v 1.6 1996/12/03 08:20:06 deraadt Exp $";
57 #endif /* LIBC_SCCS and not lint */
59 #include "libinfo_common.h"
61 #include <sys/param.h>
62 #include <sys/types.h>
63 #include <sys/socket.h>
73 #include <rpcsvc/yp.h>
74 #include <rpcsvc/ypclnt.h>
75 /* #define YPMATCHCACHE */
76 #include "ypinternal.h"
82 ypmatch_add(map
, key
, keylen
, val
, vallen
)
89 struct ypmatch_ent
*ep
;
94 for (ep
= ypmc
; ep
; ep
= ep
->next
)
98 if ((ep
= malloc(sizeof *ep
)) == NULL
)
100 (void)memset(ep
, 0, sizeof *ep
);
115 if ((ep
->key
= malloc(keylen
)) == NULL
)
118 if ((ep
->val
= malloc(vallen
)) == NULL
) {
127 (void)memcpy(ep
->key
, key
, ep
->keylen
);
128 (void)memcpy(ep
->val
, val
, ep
->vallen
);
131 if (strcmp(ep
->map
, map
)) {
133 if ((ep
->map
= strdup(map
)) == NULL
)
137 if ((ep
->map
= strdup(map
)) == NULL
)
141 ep
->expire_t
= t
+ _yplib_cache
;
146 ypmatch_find(map
, key
, keylen
, val
, vallen
)
153 struct ypmatch_ent
*ep
;
161 for (ep
= ypmc
; ep
; ep
= ep
->next
) {
162 if (ep
->keylen
!= keylen
)
164 if (strcmp(ep
->map
, map
))
166 if (memcmp(ep
->key
, key
, keylen
))
168 if (t
> ep
->expire_t
)
172 *vallen
= ep
->vallen
;
181 yp_match(indomain
, inmap
, inkey
, inkeylen
, outval
, outvallen
)
182 const char *indomain
;
189 struct dom_binding
*ysd
;
190 struct ypresp_val yprv
;
192 struct ypreq_key yprk
;
194 static int proto
= YP_BIND_UDP
;
196 if (indomain
== NULL
|| *indomain
== '\0' ||
197 strlen(indomain
) > YPMAXDOMAIN
|| inmap
== NULL
||
198 *inmap
== '\0' || strlen(inmap
) > YPMAXMAP
||
199 inkey
== NULL
|| inkeylen
== 0)
200 return YPERR_BADARGS
;
206 if (_yp_dobind(indomain
, &ysd
) != 0)
210 if (!strcmp(_yp_domain
, indomain
) && ypmatch_find(inmap
, inkey
,
211 inkeylen
, &yprv
.val
.valdat_val
, &yprv
.val
.valdat_len
)) {
212 *outvallen
= yprv
.val
.valdat_len
;
213 if ((*outval
= malloc(*outvallen
+ 1)) == NULL
) {
217 (void)memcpy(*outval
, yprv
.val
.valdat_val
, *outvallen
);
218 (*outval
)[*outvallen
] = '\0';
224 tv
.tv_sec
= _yplib_timeout
;
227 yprk
.domain
= (char *)indomain
;
228 yprk
.map
= (char *)inmap
;
229 yprk
.key
.keydat_val
= (char *) inkey
;
230 yprk
.key
.keydat_len
= inkeylen
;
232 memset(&yprv
, 0, sizeof yprv
);
234 r
= clnt_call(ysd
->dom_client
, YPPROC_MATCH
, (xdrproc_t
)xdr_ypreq_key
, &yprk
, (xdrproc_t
)xdr_ypresp_val
, &yprv
, tv
);
235 if (r
!= RPC_SUCCESS
)
237 /* call failed - switch protocols and try again */
238 if (tries
++) clnt_perror(ysd
->dom_client
, "yp_match: clnt_call");
240 if (proto
== YP_BIND_UDP
) proto
= YP_BIND_TCP
;
241 else proto
= YP_BIND_UDP
;
242 ysd
->dom_vers
= proto
;
247 if (!(r
= ypprot_err(yprv
.stat
))) {
248 *outvallen
= yprv
.val
.valdat_len
;
249 if ((*outval
= malloc(*outvallen
+ 1)) == NULL
) {
253 (void)memcpy(*outval
, yprv
.val
.valdat_val
, *outvallen
);
254 (*outval
)[*outvallen
] = '\0';
256 if (strcmp(_yp_domain
, indomain
) == 0)
257 if (!ypmatch_add(inmap
, inkey
, inkeylen
,
258 *outval
, *outvallen
))
263 xdr_free((xdrproc_t
)xdr_ypresp_val
, (char *) &yprv
);
270 yp_next(indomain
, inmap
, inkey
, inkeylen
, outkey
, outkeylen
, outval
, outvallen
)
271 const char *indomain
;
280 struct ypresp_key_val yprkv
;
281 struct ypreq_key yprk
;
282 struct dom_binding
*ysd
;
285 static int proto
= YP_BIND_UDP
;
287 if (indomain
== NULL
|| *indomain
== '\0' ||
288 strlen(indomain
) > YPMAXDOMAIN
|| inmap
== NULL
||
289 *inmap
== '\0' || strlen(inmap
) > YPMAXMAP
)
290 return YPERR_BADARGS
;
292 *outkey
= *outval
= NULL
;
293 *outkeylen
= *outvallen
= 0;
296 if (_yp_dobind(indomain
, &ysd
) != 0)
299 tv
.tv_sec
= _yplib_timeout
;
302 yprk
.domain
= (char *)indomain
;
303 yprk
.map
= (char *)inmap
;
304 yprk
.key
.keydat_val
= (char *)inkey
;
305 yprk
.key
.keydat_len
= inkeylen
;
306 (void)memset(&yprkv
, 0, sizeof yprkv
);
308 r
= clnt_call(ysd
->dom_client
, YPPROC_NEXT
, (xdrproc_t
)xdr_ypreq_key
, &yprk
, (xdrproc_t
)xdr_ypresp_key_val
, &yprkv
, tv
);
309 if (r
!= RPC_SUCCESS
)
311 /* call failed - switch protocols and try again */
312 if (tries
++) clnt_perror(ysd
->dom_client
, "yp_next: clnt_call");
314 if (proto
== YP_BIND_UDP
) proto
= YP_BIND_TCP
;
315 else proto
= YP_BIND_UDP
;
316 ysd
->dom_vers
= proto
;
321 if (!(r
= ypprot_err(yprkv
.stat
))) {
322 *outkeylen
= yprkv
.key
.keydat_len
;
323 if ((*outkey
= malloc(*outkeylen
+ 1)) == NULL
)
326 (void)memcpy(*outkey
, yprkv
.key
.keydat_val
, *outkeylen
);
327 (*outkey
)[*outkeylen
] = '\0';
329 *outvallen
= yprkv
.val
.valdat_len
;
330 if ((*outval
= malloc(*outvallen
+ 1)) == NULL
)
333 (void)memcpy(*outval
, yprkv
.val
.valdat_val
, *outvallen
);
334 (*outval
)[*outvallen
] = '\0';
337 xdr_free((xdrproc_t
)xdr_ypresp_key_val
, (char *) &yprkv
);