xref: /freebsd/share/man/man5/nsswitch.conf.5 (revision 0572ccaa4543b0abef8ef81e384c1d04de9f3da1)
1.\"	$NetBSD: nsswitch.conf.5,v 1.14 1999/03/17 20:19:47 garbled Exp $
2.\"
3.\" Copyright (c) 1997, 1998, 1999 The NetBSD Foundation, Inc.
4.\" All rights reserved.
5.\"
6.\" This code is derived from software contributed to The NetBSD Foundation
7.\" by Luke Mewburn.
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.\" 3. All advertising materials mentioning features or use of this software
18.\"    must display the following acknowledgement:
19.\" 	This product includes software developed by Luke Mewburn.
20.\" 4. The name of the author may not be used to endorse or promote products
21.\"    derived from this software without specific prior written permission.
22.\"
23.\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
24.\" IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
25.\" OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
26.\" IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
27.\" INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
28.\" BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
29.\" OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
30.\" ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR
31.\" TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
32.\" USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
33.\"
34.\" $FreeBSD$
35.\"
36.Dd December 25, 2013
37.Dt NSSWITCH.CONF 5
38.Os
39.Sh NAME
40.Nm nsswitch.conf
41.Nd name-service switch configuration file
42.Sh DESCRIPTION
43The
44.Nm
45file specifies how the
46.Xr nsdispatch 3
47(name-service switch dispatcher) routines in the C library should operate.
48.Pp
49The configuration file controls how a process looks up various databases
50containing information regarding hosts, users (passwords), groups, etc.
51Each database comes from a source (such as local files, DNS,
52.Tn NIS ,
53and cache), and the order to look up the sources is specified in
54.Nm .
55.Pp
56Each entry in
57.Nm
58consists of a database name, and a space separated list of sources.
59Each source can have an optional trailing criterion that determines
60whether the next listed source is used, or the search terminates at
61the current source.
62Each criterion consists of one or more status codes, and actions to
63take if that status code occurs.
64.Ss Sources
65The following sources are implemented:
66.Pp
67.Bl -tag -width Source -compact
68.It Sy Source
69.Sy Description
70.It files
71Local files, such as
72.Pa /etc/hosts ,
73and
74.Pa /etc/passwd .
75.It db
76Local database.
77.It dns
78Internet Domain Name System.
79.Dq hosts
80and
81.Sq networks
82use
83.Sy IN
84class entries, all other databases use
85.Sy HS
86class (Hesiod) entries.
87.It nis
88NIS (formerly YP)
89.It compat
90support
91.Sq +/-
92in the
93.Dq passwd
94and
95.Dq group
96databases.
97If this is present, it must be the only source for that entry.
98.It cache
99makes use of the
100.Xr nscd 8
101daemon.
102.El
103.Ss Databases
104The following databases are used by the following C library functions:
105.Pp
106.Bl -tag -width networks -compact
107.It Sy Database
108.Sy "Used by"
109.It group
110.Xr getgrent 3 ,
111.Xr getgrent_r 3 ,
112.Xr getgrgid_r 3 ,
113.Xr getgrnam_r 3 ,
114.Xr setgrent 3 ,
115.Xr endgrent 3
116.It hosts
117.Xr getaddrinfo 3 ,
118.Xr gethostbyaddr 3 ,
119.Xr gethostbyaddr_r 3 ,
120.Xr gethostbyname 3 ,
121.Xr gethostbyname2 3 ,
122.Xr gethostbyname_r 3 ,
123.Xr getipnodebyaddr 3 ,
124.Xr getipnodebyname 3
125.It networks
126.Xr getnetbyaddr 3 ,
127.Xr getnetbyaddr_r 3 ,
128.Xr getnetbyname 3 ,
129.Xr getnetbyname_r 3
130.It passwd
131.Xr getpwent 3 ,
132.Xr getpwent_r 3 ,
133.Xr getpwnam_r 3 ,
134.Xr getpwuid_r 3 ,
135.Xr setpwent 3 ,
136.Xr endpwent 3
137.It shells
138.Xr getusershell 3
139.It services
140.Xr getservent 3
141.It rpc
142.Xr getrpcbyname 3 ,
143.Xr getrpcbynumber 3 ,
144.Xr getrpcent 3
145.It proto
146.Xr getprotobyname 3 ,
147.Xr getprotobynumber 3 ,
148.Xr getprotoent 3
149.It netgroup
150.Xr getnetgrent 3 ,
151.Xr setnetgrent 3 ,
152.Xr innetgr 3
153.El
154.Ss Status codes
155The following status codes are available:
156.Pp
157.Bl -tag -width tryagain -compact
158.It Sy Status
159.Sy Description
160.It success
161The requested entry was found.
162.It notfound
163The entry is not present at this source.
164.It tryagain
165The source is busy, and may respond to retries.
166.It unavail
167The source is not responding, or entry is corrupt.
168.El
169.Ss Actions
170For each of the status codes, one of two actions is possible:
171.Pp
172.Bl -tag -width continue -compact
173.It Sy Action
174.Sy Description
175.It continue
176Try the next source
177.It return
178Return with the current result
179.El
180.Ss Format of file
181A
182.Tn BNF
183description of the syntax of
184.Nm
185is:
186.Pp
187.Bl -tag -width <criterion> -compact
188.It <entry>
189::=
190<database> ":" [<source> [<criteria>]]*
191.It <criteria>
192::=
193"[" <criterion>+ "]"
194.It <criterion>
195::=
196<status> "=" <action>
197.It <status>
198::=
199"success" | "notfound" | "unavail" | "tryagain"
200.It <action>
201::=
202"return" | "continue"
203.El
204.Pp
205Each entry starts on a new line in the file.
206A
207.Sq #
208delimits a comment to end of line.
209Blank lines are ignored.
210A
211.Sq \e
212at the end of a line escapes the newline, and causes the next line to
213be a continuation of the current line.
214All entries are case-insensitive.
215.Pp
216The default criteria is to return on
217.Dq success ,
218and continue on anything else (i.e,
219.Li "[success=return notfound=continue unavail=continue tryagain=continue]" ) .
220.Ss Cache
221You can enable caching for the particular database by specifying
222.Dq cache
223as the first source in the
224.Xr nsswitch.conf 5
225file.
226You should also enable caching for this database in
227.Xr nscd.conf 5 .
228If for the particular query
229.Dq cache
230source returns success, no further sources are queried.
231On the other hand, if there are no previously cached data, the
232query result will be placed into the cache right after
233all other sources are processed.
234Note, that
235.Dq cache
236requires
237.Xr nscd 8
238daemon to be running.
239.Ss Compat mode: +/- syntax
240In historical multi-source implementations, the
241.Sq +
242and
243.Sq -
244characters are used to specify the importing of user password and
245group information from
246.Tn NIS .
247Although
248.Nm
249provides alternative methods of accessing distributed sources such as
250.Tn NIS ,
251specifying a sole source of
252.Dq compat
253will provide the historical behaviour.
254.Pp
255An alternative source for the information accessed via
256.Sq +/-
257can be used by specifying
258.Dq passwd_compat: source .
259.Dq source
260in this case can be
261.Sq dns ,
262.Sq nis ,
263or
264any other source except for
265.Sq files
266and
267.Sq compat .
268.Ss Notes
269Historically, many of the databases had enumeration functions, often of
270the form
271.Fn getXXXent .
272These made sense when the databases were in local files, but do not make
273sense or have lesser relevance when there are possibly multiple sources,
274each of an unknown size.
275The interfaces are still provided for compatibility, but the source
276may not be able to provide complete entries, or duplicate entries may
277be retrieved if multiple sources that contain similar information are
278specified.
279.Pp
280To ensure compatibility with previous and current implementations, the
281.Dq compat
282source must appear alone for a given database.
283.Ss Default source lists
284If, for any reason,
285.Nm
286does not exist, or it has missing or corrupt entries,
287.Xr nsdispatch 3
288will default to an entry of
289.Dq files
290for the requested database.
291Exceptions are:
292.Pp
293.Bl -tag -width services_compat -compact
294.It Sy Database
295.Sy "Default source list"
296.It group
297compat
298.It group_compat
299nis
300.It hosts
301files dns
302.It passwd
303compat
304.It passwd_compat
305nis
306.It services
307compat
308.It services_compat
309nis
310.El
311.Sh FILES
312.Bl -tag -width /etc/nsswitch.conf -compact
313.It Pa /etc/nsswitch.conf
314The file
315.Nm
316resides in
317.Pa /etc .
318.El
319.Sh EXAMPLES
320To lookup hosts in cache, then in
321.Pa /etc/hosts
322and then from the DNS, and lookup user information from
323.Tn NIS
324then files, use:
325.Pp
326.Bl -tag -width passwd: -compact
327.It hosts:
328cache files dns
329.It passwd:
330nis [notfound=return] files
331.It group:
332nis [notfound=return] files
333.El
334.Pp
335The criteria
336.Dq [notfound=return]
337sets a policy of "if the user is notfound in nis, do not try files."
338This treats nis as the authoritative source of information, except
339when the server is down.
340.Sh NOTES
341If system got compiled with
342.Va WITHOUT_NIS
343you have to remove
344.Sq nis
345entries.
346.Pp
347.Fx Ns 's
348.Lb libc
349provides stubs for compatibility with NSS modules
350written for the
351.Tn GNU
352C Library
353.Nm nsswitch
354interface.
355However, these stubs only support the use of the
356.Dq Li passwd
357and
358.Dq Li group
359databases.
360.Sh SEE ALSO
361.Xr nsdispatch 3 ,
362.Xr nscd.conf 5 ,
363.Xr resolv.conf 5 ,
364.Xr nscd 8 ,
365.Xr ypbind 8
366.Sh HISTORY
367The
368.Nm
369file format first appeared in
370.Fx 5.0 .
371It was imported from the
372.Nx
373Project, where it appeared first in
374.Nx 1.4 .
375.Sh AUTHORS
376Luke Mewburn
377.Aq lukem@netbsd.org
378wrote this freely distributable name-service switch implementation,
379using ideas from the
380.Tn ULTRIX
381.Xr svc.conf 5
382and
383.Tn Solaris
384.Xr nsswitch.conf 4
385manual pages.
386