]>
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
;
192 if (indomain
== NULL
|| *indomain
== '\0' ||
193 strlen(indomain
) > YPMAXDOMAIN
|| inmap
== NULL
||
194 *inmap
== '\0' || strlen(inmap
) > YPMAXMAP
||
195 inkey
== NULL
|| inkeylen
== 0)
196 return YPERR_BADARGS
;
202 if (_yp_dobind(indomain
, &ysd
) != 0)
206 if (!strcmp(_yp_domain
, indomain
) && ypmatch_find(inmap
, inkey
,
207 inkeylen
, &yprv
.val
.valdat_val
, &yprv
.val
.valdat_len
)) {
208 *outvallen
= yprv
.val
.valdat_len
;
209 if ((*outval
= malloc(*outvallen
+ 1)) == NULL
) {
213 (void)memcpy(*outval
, yprv
.val
.valdat_val
, *outvallen
);
214 (*outval
)[*outvallen
] = '\0';
220 tv
.tv_sec
= _yplib_timeout
;
223 yprk
.domain
= (char *)indomain
;
224 yprk
.map
= (char *)inmap
;
225 yprk
.key
.keydat_val
= (char *) inkey
;
226 yprk
.key
.keydat_len
= inkeylen
;
228 memset(&yprv
, 0, sizeof yprv
);
230 r
= clnt_call(ysd
->dom_client
, YPPROC_MATCH
,
231 xdr_ypreq_key
, &yprk
, xdr_ypresp_val
, &yprv
, tv
);
232 if (r
!= RPC_SUCCESS
) {
234 clnt_perror(ysd
->dom_client
, "yp_match: clnt_call");
238 if (!(r
= ypprot_err(yprv
.stat
))) {
239 *outvallen
= yprv
.val
.valdat_len
;
240 if ((*outval
= malloc(*outvallen
+ 1)) == NULL
) {
244 (void)memcpy(*outval
, yprv
.val
.valdat_val
, *outvallen
);
245 (*outval
)[*outvallen
] = '\0';
247 if (strcmp(_yp_domain
, indomain
) == 0)
248 if (!ypmatch_add(inmap
, inkey
, inkeylen
,
249 *outval
, *outvallen
))
254 xdr_free(xdr_ypresp_val
, (char *) &yprv
);
260 yp_next(indomain
, inmap
, inkey
, inkeylen
, outkey
, outkeylen
, outval
, outvallen
)
261 const char *indomain
;
270 struct ypresp_key_val yprkv
;
271 struct ypreq_key yprk
;
272 struct dom_binding
*ysd
;
276 if (indomain
== NULL
|| *indomain
== '\0' ||
277 strlen(indomain
) > YPMAXDOMAIN
|| inmap
== NULL
||
278 *inmap
== '\0' || strlen(inmap
) > YPMAXMAP
)
279 return YPERR_BADARGS
;
281 *outkey
= *outval
= NULL
;
282 *outkeylen
= *outvallen
= 0;
285 if (_yp_dobind(indomain
, &ysd
) != 0)
288 tv
.tv_sec
= _yplib_timeout
;
291 yprk
.domain
= (char *)indomain
;
292 yprk
.map
= (char *)inmap
;
293 yprk
.key
.keydat_val
= (char *)inkey
;
294 yprk
.key
.keydat_len
= inkeylen
;
295 (void)memset(&yprkv
, 0, sizeof yprkv
);
297 r
= clnt_call(ysd
->dom_client
, YPPROC_NEXT
,
298 xdr_ypreq_key
, &yprk
, xdr_ypresp_key_val
, &yprkv
, tv
);
299 if (r
!= RPC_SUCCESS
) {
301 clnt_perror(ysd
->dom_client
, "yp_next: clnt_call");
305 if (!(r
= ypprot_err(yprkv
.stat
))) {
306 *outkeylen
= yprkv
.key
.keydat_len
;
307 if ((*outkey
= malloc(*outkeylen
+ 1)) == NULL
)
310 (void)memcpy(*outkey
, yprkv
.key
.keydat_val
, *outkeylen
);
311 (*outkey
)[*outkeylen
] = '\0';
313 *outvallen
= yprkv
.val
.valdat_len
;
314 if ((*outval
= malloc(*outvallen
+ 1)) == NULL
)
317 (void)memcpy(*outval
, yprkv
.val
.valdat_val
, *outvallen
);
318 (*outval
)[*outvallen
] = '\0';
321 xdr_free(xdr_ypresp_key_val
, (char *) &yprkv
);