|
NAMEnsdispatch —
name-service switch dispatcher routine
LIBRARYStandard C Library (libc, -lc)SYNOPSIS#include <sys/types.h>
#include <stdarg.h>
#include <nsswitch.h>
int
DESCRIPTIONThensdispatch () function invokes the methods specified
in dtab in the order given by
nsswitch.conf(5)
for the database database until a successful entry is
found.
retval is passed to each method to modify as
necessary, to pass back results to the caller of
Each method has the function signature described by the typedef: typedef int
dtab is an array of ns_dtab structures, which have the following format: typedef struct _ns_dtab { const char *src; nss_method method; void *mdata; } ns_dtab; The dtab array should consist of one entry
for each source type that is implemented, with src as
the name of the source, method as a function which
handles that source, and mdata as a handle on
arbitrary data to be passed to the method. The last entry in
dtab should contain Additionally, methods may be implemented in NSS modules, in which case they are selected using the database and method_name arguments along with the configured source. Modules must use source names different from the built-in ones. defaults contains a list of default sources to try if nsswitch.conf(5) is missing or corrupted, or if there is no relevant entry for database. It is an array of ns_src structures, which have the following format: typedef struct _ns_src { const char *src; uint32_t flags; } ns_src; The defaults array should consist of one
entry for each source to be configured by default indicated by
src, and flags set to the
criterion desired (usually For convenience, a global variable defined as: extern const ns_src
__nsdefaultsrc[]; exists which contains a single default entry for the source ‘files’ that may be used by callers which do not require complicated default rules. ‘...’ are optional extra arguments, which are passed to the appropriate method as a variable argument list of the type va_list. Valid source typesWhile there is support for arbitrary sources, the following #defines for commonly implemented sources are available:
Refer to nsswitch.conf(5) for a complete description of what each source type is. Method return valuesThe nss_method functions must return one of the following values depending upon status of the lookup:
Refer to nsswitch.conf(5) for a complete description of each status code. The NOTESFreeBSD's Standard C Library (libc, -lc) provides stubs for compatibility with NSS modules written for the GNU C Librarynsswitch interface. However,
these stubs only support the use of the
“passwd ” and
“group ” databases.
SEE ALSOhesiod(3), stdarg(3), nsswitch.conf(5), yp(8)HISTORYThensdispatch () function first appeared in
FreeBSD 5.0. It was imported from the
NetBSD Project, where it appeared first in
NetBSD 1.4. Support for NSS modules first appeared in
FreeBSD 5.1.
AUTHORSLuke Mewburn <lukem@netbsd.org> wrote this freely-distributable name-service switch implementation, using ideas from the ULTRIX svc.conf(5) and Solaris nsswitch.conf(4) manual pages. The FreeBSD Project added the support for threads and NSS modules, and normalized the uses ofnsdispatch ()
within the standard C library.
Visit the GSP FreeBSD Man Page Interface. |