Expand PMF_FN_* macros.
[netbsd-mini2440.git] / usr.sbin / ypserv / revnetgroup / revnetgroup.8
blob97668635b5c7f44b6183246952432673458db15a
1 .\"     $NetBSD: revnetgroup.8,v 1.9 2005/02/26 16:28:40 thorpej Exp $
2 .\"
3 .\" Copyright (c) 1995
4 .\"     Bill Paul <wpaul@ctr.columbia.edu>.  All rights reserved.
5 .\"
6 .\" Redistribution and use in source and binary forms, with or without
7 .\" modification, are permitted provided that the following conditions
8 .\" are met:
9 .\" 1. Redistributions of source code must retain the above copyright
10 .\"    notice, this list of conditions and the following disclaimer.
11 .\" 2. Redistributions in binary form must reproduce the above copyright
12 .\"    notice, this list of conditions and the following disclaimer in the
13 .\"    documentation and/or other materials provided with the distribution.
14 .\" 3. All advertising materials mentioning features or use of this software
15 .\"    must display the following acknowledgement:
16 .\"     This product includes software developed by Bill Paul.
17 .\" 4. Neither the name of the University nor the names of its contributors
18 .\"    may be used to endorse or promote products derived from this software
19 .\"    without specific prior written permission.
20 .\"
21 .\" THIS SOFTWARE IS PROVIDED BY Bill Paul AND CONTRIBUTORS ``AS IS'' AND
22 .\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
23 .\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
24 .\" ARE DISCLAIMED.  IN NO EVENT SHALL Bill Paul OR CONTRIBUTORS BE LIABLE
25 .\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
26 .\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
27 .\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
28 .\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
29 .\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
30 .\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
31 .\" SUCH DAMAGE.
32 .\"
33 .Dd February 26, 2005
34 .Dt REVNETGROUP 8
35 .Os
36 .Sh NAME
37 .Nm revnetgroup
38 .Nd generate reverse netgroup data
39 .Sh SYNOPSIS
40 .Nm
41 .Op Fl uh
42 .Bk -words
43 .Op Fl f Ar netgroup_file
44 .Ek
45 .Sh DESCRIPTION
46 .Nm
47 processes the contents of a file in
48 .Xr netgroup 5
49 format into what is called
50 .Pa reverse netgroup
51 form. That is, where the original file shows
52 netgroup memberships in terms of which members reside in a particular
53 group, the reverse netgroup format specifies what groups are associated
54 with a particular member. This information is used to generate the
55 .Pa netgroup.byuser
56 and
57 .Pa netgroup.byhosts
58 .Tn NIS
59 maps. These reverse netgroup maps are used to help speed up
60 netgroup lookups, particularly for the
61 .Fn innetgr
62 library function.
63 .Pp
64 For example, the standard
65 .Pa /etc/netgroup
66 file may list a netgroup and a list of its members. Here, the
67 netgroup is considered the
68 .Pa key
69 and the member names are the
70 .Pa data .
71 By contrast, the reverse
72 .Pa netgroup.byusers
73 database lists each unique
74 member as the key and the netgroups to which the members belong become
75 the data. Separate databases are created to hold information pertaining
76 to users and hosts; this allows netgroup username lookups
77 and netgroup hostname lookups to be performed using independent keyspaces.
78 .Pp
79 By constructing these reverse netgroup databases (and the corresponding
80 .Tn NIS
81 maps) in advance, the
82 .Xr getnetgrent 3
83 library functions are spared from having to work out the dependencies
84 themselves on the fly. This is important on networks with large numbers
85 of users and hosts, since it can take a considerable amount of time
86 to process very large netgroup databases.
87 .Pp
88 The
89 .Nm
90 command prints its results on the standard output. It is usually called
91 only by
92 .Pa /var/yp/\*[Lt]domain\*[Gt]/Makefile
93 when rebuilding the
94 .Tn NIS
95 netgroup maps.
96 .Sh OPTIONS
97 The
98 .Nm
99 command supports the following options:
100 .Bl -tag -width flag
101 .It Fl u
102 Generate netgroup.byuser output; only username information in the
103 original netgroup file is processed.
104 .It Fl h
105 Generate netgroup.byhost output; only hostname information in the
106 original netgroup file is processed. (Note at least one of the
107 .Fl u
109 .Fl h
110 flags must be specified.)
111 .It Op Fl f Ar netgroup_file
114 command uses
115 .Pa /etc/netgroup
116 as its default input file. The
117 .Fl f
118 flag allows the user to specify an alternate input file. Specifying ``-''
119 as the input file causes
121 to read from the standard input.
123 .Sh FILES
124 .Bl -tag -width Pa -compact
125 .It Pa /var/yp/\*[Lt]domain\*[Gt]/Makefile
126 The Makefile that calls
127 .Nm makedbm
129 .Nm revnetgroup
130 to build the
131 .Tn NIS
132 databases.
133 .It Pa /etc/netgroup
134 The default netgroup database file. This file is most often found
135 only on the
136 .Tn NIS
137 master server.
139 .Sh SEE ALSO
140 .Xr getnetgrent 3 ,
141 .Xr netgroup 5 ,
142 .Xr makedbm 8 ,
143 .Xr nis 8
144 .Sh AUTHORS
145 .An Bill Paul Aq wpaul@ctr.columbia.edu