Expand PMF_FN_* macros.
[netbsd-mini2440.git] / lib / libc / yp / ypclnt.3
blob36253e63a46de5845dbdd19c2d74cac479709996
1 .\"     $NetBSD: ypclnt.3,v 1.22 2003/05/10 12:14:27 wiz Exp $
2 .\"
3 .\" Copyright (c) 1996 The NetBSD Foundation, Inc.
4 .\" All rights reserved.
5 .\"
6 .\" This code is derived from software contributed to The NetBSD Foundation
7 .\" by Jason R. Thorpe.
8 .\"
9 .\" Redistribution and use in source and binary forms, with or without
10 .\" modification, are permitted provided that the following conditions
11 .\" are met:
12 .\" 1. Redistributions of source code must retain the above copyright
13 .\"    notice, this list of conditions and the following disclaimer.
14 .\" 2. Redistributions in binary form must reproduce the above copyright
15 .\"    notice, this list of conditions and the following disclaimer in the
16 .\"    documentation and/or other materials provided with the distribution.
17 .\"
18 .\" THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
19 .\" ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
20 .\" TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
21 .\" PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
22 .\" BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
23 .\" CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
24 .\" SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
25 .\" INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
26 .\" CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
27 .\" ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
28 .\" POSSIBILITY OF SUCH DAMAGE.
29 .\"
30 .Dd May 21, 1997
31 .Dt YPCLNT 3
32 .Os
33 .Sh NAME
34 .Nm yp_all ,
35 .Nm yp_bind ,
36 .Nm yp_first ,
37 .Nm yp_get_default_domain ,
38 .Nm yp_master ,
39 .Nm yp_match ,
40 .Nm yp_next ,
41 .Nm yp_order ,
42 .Nm yp_unbind ,
43 .Nm yperr_string ,
44 .Nm ypprot_err
45 .Nd Interface to the YP subsystem
46 .Sh LIBRARY
47 .Lb libc
48 .Sh SYNOPSIS
49 .In sys/types.h
50 .In rpc/rpc.h
51 .In rpcsvc/ypclnt.h
52 .In rpcsvc/yp_prot.h
53 .Ft int
54 .Fn yp_all "const char *indomain" "const char *inmap" "struct ypall_callback *incallback"
55 .Ft int
56 .Fn yp_bind "const char *dom"
57 .Ft int
58 .Fn yp_first "const char *indomain" "const char *inmap" "char **outkey" "int *outkeylen" "char **outval" "int *outvallen"
59 .Ft int
60 .Fn yp_get_default_domain "char **outdomain"
61 .Ft int
62 .Fn yp_master "const char *indomain" "const char *inmap" "char **outname"
63 .Ft int
64 .Fn yp_match "const char *indomain" "const char *inmap" "const char *inkey" "int inkeylen" "char **outval" "int *outvallen"
65 .Ft int
66 .Fn yp_next "const char *indomain" "const char *inmap" "const char *inkey" "int inkeylen" "char **outkey" "int *outkeylen" "char **outval" "int *outvallen"
67 .Ft int
68 .Fn yp_order "const char *indomain" "const char *inmap" "int *outorder"
69 .Ft void
70 .Fn yp_unbind "const char *dom"
71 .Ft char *
72 .Fn yperr_string "int incode"
73 .Ft int
74 .Fn ypprot_err "unsigned int incode"
75 .Sh DESCRIPTION
76 The
77 .Nm ypclnt
78 suite provides an interface to the
79 .Tn YP
80 subsystem.
81 For a general description of the
82 .Tn YP
83 subsystem, see
84 .Xr yp 8 .
85 .Pp
86 For all functions, input values begin with
87 .Pa in
88 and output values begin with
89 .Pa out .
90 .Pp
91 Any output values of type
92 .Em char **
93 should be the addresses of uninitialized character pointers.
94 These values will be reset to the null pointer (unless the address
95 itself is the null pointer, in which case the error
96 .Er YPERR_BADARGS
97 will be returned).
98 If necessary,
99 memory will be allocated by the
100 .Tn YP
101 client routines using
102 .Fn malloc ,
103 and the result will be stored in the appropriate output value.
104 If the invocation of a
105 .Tn YP
106 client routine doesn't return an error,
107 and an output value is not the null pointer, then this memory
108 should be freed by the user when there is no additional need for
109 the data stored there.
111 .Pa outkey
113 .Pa outval ,
114 two extra bytes of memory are allocated for a
115 .Ql \en
117 .Ql \e0 ,
118 which are not
119 reflected in the values of
120 .Pa outkeylen
122 .Pa outvallen .
124 All occurrences of
125 .Pa indomain
127 .Pa inmap
128 must be non-null, NUL-terminated strings.
129 All input strings which also have
130 a corresponding length parameter cannot be the null pointer unless the
131 corresponding length value is zero.
132 Such strings need not be NUL-terminated.
135 .Tn YP
136 lookup calls (the functions
137 .Fn yp_all ,
138 .Fn yp_first ,
139 .Fn yp_master ,
140 .Fn yp_match ,
141 .Fn yp_next ,
142 .Fn yp_order )
143 require a
144 .Tn YP
145 domain name and a
146 .Tn YP
147 map name.
148 The default domain name may be obtained by calling
149 .Fn yp_get_default_domain ,
150 and should thus be used before all other
151 .Tn YP
152 calls in a client program.
153 The value it places
154 .Pa outdomain
155 is suitable for use as the
156 .Pa indomain
157 parameter to all subsequent
158 .Tn YP
159 calls.
161 In order for
162 .Tn YP
163 lookup calls to succeed, the client process must be bound
164 to a
165 .Tn YP
166 server process.
167 The client process need not explicitly bind to
168 the server, as it happens automatically whenever a lookup occurs.
169 The function
170 .Fn yp_bind
171 is provided for a backup strategy, e.g. a local file, when a
172 .Tn YP
173 server process is not available.
174 Each binding uses one socket descriptor on the client
175 process, which may be explicitly freed using
176 .Fn yp_unbind ,
177 which frees all per-process and per-node resources to bind the domain and
178 marks the domain unbound.
180 If, during a
181 .Tn YP
182 lookup, an RPC failure occurs, the domain used in the lookup
183 is automatically marked unbound and the
184 .Nm ypclnt
185 layer retries the lookup as long as
186 .Xr ypbind 8
187 is running and either the client process cannot bind to a server for the domain
188 specified in the lookup, or RPC requests to the
189 .Tn YP
190 server process fail.
191 If an error is not RPC-related, one of the
192 .Tn YP
193 error codes described below
194 is returned and control given back to the user code.
197 .Nm ypclnt
198 suite provides the following functionality:
199 .Bl -tag -width yp_match()xx
200 .It Fn yp_match
201 Provides the value associated with the given key.
202 .It Fn yp_first
203 Provides the first key-value pair from the given map in the named domain.
204 .It Fn yp_next
205 Provides the next key-value pair in the given map.
206 To obtain the second pair,
208 .Pa inkey
209 value should be the
210 .Pa outkey
211 value provided by the initial call to
212 .Fn yp_first .
213 In the general case, the next key-value pair may be obtained by using the
214 .Pa outkey
215 value from the previous call to
216 .Fn yp_next
217 as the value for
218 .Pa inkey .
220 Of course, the notions of
221 .Dq first
223 .Dq next
224 are particular to the
225 type of
226 .Tn YP
227 map being accessed, and thus there is no guarantee of lexical order.
228 The only guarantees provided with
229 .Fn yp_first
231 .Fn yp_next ,
232 providing that the same map on the same server is polled repeatedly until
233 .Fn yp_next
234 returns YPERR_NOMORE, are that all key-value pairs in that map will be accessed
235 exactly once, and if the entire procedure is repeated, the order will be
236 the same.
238 If the server is heavily loaded or the server fails for some reason, the
239 domain being used may become unbound.
240 If this happens, and the client process re-binds, the retrieval rules
241 will break: some entries may be seen twice, and others not at all.
242 For this reason, the function
243 .Fn yp_all
244 provides a better solution for reading all of the entries in a particular map.
245 .It Fn yp_all
246 This function provides a way to transfer an entire map from
247 the server to the client process with a single request.
248 This transfer uses TCP, unlike all other functions in the
249 .Nm ypclnt
250 suite, which use UDP.
251 The entire transaction occurs in a single RPC request-response.
252 The third argument to this function provides a way to supply
253 the name of a function to process each key-value pair in the map.
254 .Fn yp_all
255 returns after the entire transaction is complete, or the
256 .Pa foreach
257 function decides that it does not want any more key-value pairs.
258 The third argument to
259 .Fn yp_all
261 .Bd -literal -offset indent
262 struct ypall_callback *incallback {
263         int (*foreach)();
264         char *data;
269 .Em char *data
270 argument is an opaque pointer for use by the callback function.
272 .Pa foreach
273 function should return non-zero when it no longer wishes to process
274 key-value pairs, at which time
275 .Fn yp_all
276 returns a value of 0, and is called with the following arguments:
278 .Bd -literal -offset indent
279 int foreach (
280         int instatus,
281         char *inkey,
282         int inkeylen,
283         char *inval,
284         int invallen,
285         char *indata
289 Where:
290 .Bl -tag -width "inkey, inval"
291 .It Fa instatus
292 Holds one of the return status values described in
293 .Aq Pa rpcsvc/yp_prot.h :
295 .Fn ypprot_err
296 below for a function that will translate
297 .Tn YP
298 protocol errors into a
299 .Nm ypclnt
300 layer error code as described in
301 .Aq Pa rpcsvc/ypclnt.h .
302 .It Fa inkey, inval
303 The key and value arguments are somewhat different here than described
304 above.
305 In this case, the memory pointed to by
306 .Fa inkey
308 .Fa inval
309 is private to
310 .Fn yp_all ,
311 and is overwritten with each subsequent key-value pair, thus the
312 .Pa foreach
313 function should do something useful with the contents of that memory during
314 each iteration.
315 If the key-value pairs are not terminated with either
316 .Ql \en
318 .Ql \e0
319 in the map, then they will not be terminated as such when given to the
320 .Pa foreach
321 function, either.
322 .It Fa indata
323 This is the contents of the
324 .Pa incallback-\*[Gt]data
325 element of the callback structure.
326 It is provided as a means to share state between the
327 .Pa foreach
328 function and the user code.
329 Its use is completely optional: cast it to
330 something useful or simply ignore it.
332 .It Fn yp_order
333 Returns the order number for a map.
334 .It Fn yp_master
335 Returns the hostname for the machine on which the master
336 .Tn YP
337 server process for
338 a map is running.
339 .It Fn yperr_string
340 Returns a pointer to a NUL-terminated error string that does not contain a
341 .Ql \&.
343 .Ql \en .
344 .It Fn ypprot_err
345 Converts a
346 .Tn YP
347 protocol error code to a
348 .Nm ypclnt
349 error code suitable for
350 .Fn yperr_string .
352 .Sh RETURN VALUES
353 All functions in the
354 .Nm ypclnt
355 suite which are of type
356 .Em int
357 return 0 upon success or one of the following error codes upon failure:
358 .Bl -tag -width "YPERR_BADARGS   "
359 .It Bq Er YPERR_BADARGS
360 The passed arguments to the function are invalid.
361 .It Bq Er YPERR_BADDB
363 .Tn YP
364 map that was polled is defective.
365 .It Bq Er YPERR_DOMAIN
366 Client process cannot bind to server on this
367 .Tn YP
368 domain.
369 .It Bq Er YPERR_KEY
370 The key passed does not exist.
371 .It Bq Er YPERR_MAP
372 There is no such map in the server's domain.
373 .It Bq Er YPERR_DOM
374 The local
375 .Tn YP
376 domain is not set.
377 .It Bq Er YPERR_NOMORE
378 There are no more records in the queried map.
379 .It Bq Er YPERR_PMAP
380 Cannot communicate with portmapper (see
381 .Xr rpcbind 8 ) .
382 .It Bq Er YPERR_RESRC
383 A resource allocation failure occurred.
384 .It Bq Er YPERR_RPC
385 An RPC failure has occurred.
386 The domain has been marked unbound.
387 .It Bq Er YPERR_VERS
388 Client/server version mismatch.
389 If the server is running version 1 of the
390 .Tn YP
391 protocol,
392 .Fn yp_all
393 functionality does not exist.
394 .It Bq Er YPERR_BIND
395 Cannot communicate with
396 .Xr ypbind 8 .
397 .It Bq Er YPERR_YPERR
398 An internal server or client error has occurred.
399 .It Bq Er YPERR_YPSERV
400 The client cannot communicate with the
401 .Tn YP
402 server process.
404 .Sh SEE ALSO
405 .Xr malloc 3 ,
406 .Xr yp 8 ,
407 .Xr ypbind 8 ,
408 .Xr ypserv 8
409 .Sh AUTHORS
410 .An Theo De Raadt