]>
git.saurik.com Git - apple/libinfo.git/blob - nis.subproj/ypmatch_cache.c
2 * Copyright (c) 1999 Apple Computer, 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 <sys/param.h>
60 #include <sys/types.h>
61 #include <sys/socket.h>
71 #include <rpcsvc/yp.h>
72 #include <rpcsvc/ypclnt.h>
73 /* #define YPMATCHCACHE */
74 #include "ypinternal.h"
80 ypmatch_add(map
, key
, keylen
, val
, vallen
)
87 struct ypmatch_ent
*ep
;
92 for (ep
= ypmc
; ep
; ep
= ep
->next
)
96 if ((ep
= malloc(sizeof *ep
)) == NULL
)
98 (void)memset(ep
, 0, sizeof *ep
);
113 if ((ep
->key
= malloc(keylen
)) == NULL
)
116 if ((ep
->val
= malloc(vallen
)) == NULL
) {
125 (void)memcpy(ep
->key
, key
, ep
->keylen
);
126 (void)memcpy(ep
->val
, val
, ep
->vallen
);
129 if (strcmp(ep
->map
, map
)) {
131 if ((ep
->map
= strdup(map
)) == NULL
)
135 if ((ep
->map
= strdup(map
)) == NULL
)
139 ep
->expire_t
= t
+ _yplib_cache
;
144 ypmatch_find(map
, key
, keylen
, val
, vallen
)
151 struct ypmatch_ent
*ep
;
159 for (ep
= ypmc
; ep
; ep
= ep
->next
) {
160 if (ep
->keylen
!= keylen
)
162 if (strcmp(ep
->map
, map
))
164 if (memcmp(ep
->key
, key
, keylen
))
166 if (t
> ep
->expire_t
)
170 *vallen
= ep
->vallen
;
178 yp_match(indomain
, inmap
, inkey
, inkeylen
, outval
, outvallen
)
179 const char *indomain
;
186 struct dom_binding
*ysd
;
187 struct ypresp_val yprv
;
189 struct ypreq_key yprk
;
191 static int proto
= YP_BIND_UDP
;
193 if (indomain
== NULL
|| *indomain
== '\0' ||
194 strlen(indomain
) > YPMAXDOMAIN
|| inmap
== NULL
||
195 *inmap
== '\0' || strlen(inmap
) > YPMAXMAP
||
196 inkey
== NULL
|| inkeylen
== 0)
197 return YPERR_BADARGS
;
203 if (_yp_dobind(indomain
, &ysd
) != 0)
207 if (!strcmp(_yp_domain
, indomain
) && ypmatch_find(inmap
, inkey
,
208 inkeylen
, &yprv
.val
.valdat_val
, &yprv
.val
.valdat_len
)) {
209 *outvallen
= yprv
.val
.valdat_len
;
210 if ((*outval
= malloc(*outvallen
+ 1)) == NULL
) {
214 (void)memcpy(*outval
, yprv
.val
.valdat_val
, *outvallen
);
215 (*outval
)[*outvallen
] = '\0';
221 tv
.tv_sec
= _yplib_timeout
;
224 yprk
.domain
= (char *)indomain
;
225 yprk
.map
= (char *)inmap
;
226 yprk
.key
.keydat_val
= (char *) inkey
;
227 yprk
.key
.keydat_len
= inkeylen
;
229 memset(&yprv
, 0, sizeof yprv
);
231 r
= clnt_call(ysd
->dom_client
, YPPROC_MATCH
, (xdrproc_t
)xdr_ypreq_key
, &yprk
, (xdrproc_t
)xdr_ypresp_val
, &yprv
, tv
);
232 if (r
!= RPC_SUCCESS
)
234 /* call failed - switch protocols and try again */
235 if (tries
++) clnt_perror(ysd
->dom_client
, "yp_match: clnt_call");
237 if (proto
== YP_BIND_UDP
) proto
= YP_BIND_TCP
;
238 else proto
= YP_BIND_UDP
;
239 ysd
->dom_vers
= proto
;
244 if (!(r
= ypprot_err(yprv
.stat
))) {
245 *outvallen
= yprv
.val
.valdat_len
;
246 if ((*outval
= malloc(*outvallen
+ 1)) == NULL
) {
250 (void)memcpy(*outval
, yprv
.val
.valdat_val
, *outvallen
);
251 (*outval
)[*outvallen
] = '\0';
253 if (strcmp(_yp_domain
, indomain
) == 0)
254 if (!ypmatch_add(inmap
, inkey
, inkeylen
,
255 *outval
, *outvallen
))
260 xdr_free((xdrproc_t
)xdr_ypresp_val
, (char *) &yprv
);
266 yp_next(indomain
, inmap
, inkey
, inkeylen
, outkey
, outkeylen
, outval
, outvallen
)
267 const char *indomain
;
276 struct ypresp_key_val yprkv
;
277 struct ypreq_key yprk
;
278 struct dom_binding
*ysd
;
281 static int proto
= YP_BIND_UDP
;
283 if (indomain
== NULL
|| *indomain
== '\0' ||
284 strlen(indomain
) > YPMAXDOMAIN
|| inmap
== NULL
||
285 *inmap
== '\0' || strlen(inmap
) > YPMAXMAP
)
286 return YPERR_BADARGS
;
288 *outkey
= *outval
= NULL
;
289 *outkeylen
= *outvallen
= 0;
292 if (_yp_dobind(indomain
, &ysd
) != 0)
295 tv
.tv_sec
= _yplib_timeout
;
298 yprk
.domain
= (char *)indomain
;
299 yprk
.map
= (char *)inmap
;
300 yprk
.key
.keydat_val
= (char *)inkey
;
301 yprk
.key
.keydat_len
= inkeylen
;
302 (void)memset(&yprkv
, 0, sizeof yprkv
);
304 r
= clnt_call(ysd
->dom_client
, YPPROC_NEXT
, (xdrproc_t
)xdr_ypreq_key
, &yprk
, (xdrproc_t
)xdr_ypresp_key_val
, &yprkv
, tv
);
305 if (r
!= RPC_SUCCESS
)
307 /* call failed - switch protocols and try again */
308 if (tries
++) clnt_perror(ysd
->dom_client
, "yp_next: clnt_call");
310 if (proto
== YP_BIND_UDP
) proto
= YP_BIND_TCP
;
311 else proto
= YP_BIND_UDP
;
312 ysd
->dom_vers
= proto
;
317 if (!(r
= ypprot_err(yprkv
.stat
))) {
318 *outkeylen
= yprkv
.key
.keydat_len
;
319 if ((*outkey
= malloc(*outkeylen
+ 1)) == NULL
)
322 (void)memcpy(*outkey
, yprkv
.key
.keydat_val
, *outkeylen
);
323 (*outkey
)[*outkeylen
] = '\0';
325 *outvallen
= yprkv
.val
.valdat_len
;
326 if ((*outval
= malloc(*outvallen
+ 1)) == NULL
)
329 (void)memcpy(*outval
, yprkv
.val
.valdat_val
, *outvallen
);
330 (*outval
)[*outvallen
] = '\0';
333 xdr_free((xdrproc_t
)xdr_ypresp_key_val
, (char *) &yprkv
);