180 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			Groff
		
	
	
	
	
	
			
		
		
	
	
			180 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			Groff
		
	
	
	
	
	
.\"	$NetBSD: ftpusers.5,v 1.17 2008/09/13 02:41:52 lukem Exp $
 | 
						|
.\"
 | 
						|
.\" Copyright (c) 1997-2008 The NetBSD Foundation, Inc.
 | 
						|
.\" All rights reserved.
 | 
						|
.\"
 | 
						|
.\" This code is derived from software contributed to The NetBSD Foundation
 | 
						|
.\" by Luke Mewburn.
 | 
						|
.\"
 | 
						|
.\" Redistribution and use in source and binary forms, with or without
 | 
						|
.\" modification, are permitted provided that the following conditions
 | 
						|
.\" are met:
 | 
						|
.\" 1. Redistributions of source code must retain the above copyright
 | 
						|
.\"    notice, this list of conditions and the following disclaimer.
 | 
						|
.\" 2. Redistributions in binary form must reproduce the above copyright
 | 
						|
.\"    notice, this list of conditions and the following disclaimer in the
 | 
						|
.\"    documentation and/or other materials provided with the distribution.
 | 
						|
.\"
 | 
						|
.\" THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
 | 
						|
.\" ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
 | 
						|
.\" TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
 | 
						|
.\" PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
 | 
						|
.\" BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
 | 
						|
.\" CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
 | 
						|
.\" SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
 | 
						|
.\" INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
 | 
						|
.\" CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
 | 
						|
.\" ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
 | 
						|
.\" POSSIBILITY OF SUCH DAMAGE.
 | 
						|
.\"
 | 
						|
.Dd July 17, 2000
 | 
						|
.Dt FTPUSERS 5
 | 
						|
.Os
 | 
						|
.Sh NAME
 | 
						|
.Nm ftpusers ,
 | 
						|
.Nm ftpchroot
 | 
						|
.Nd
 | 
						|
.Xr ftpd 8
 | 
						|
access control file
 | 
						|
.Sh DESCRIPTION
 | 
						|
The
 | 
						|
.Nm
 | 
						|
file provides user access control for
 | 
						|
.Xr ftpd 8
 | 
						|
by defining which users may login.
 | 
						|
.Pp
 | 
						|
If the
 | 
						|
.Nm
 | 
						|
file does not exist, all users are denied access.
 | 
						|
.Pp
 | 
						|
A
 | 
						|
.Dq \e
 | 
						|
is the escape character; it can be used to escape the meaning of the
 | 
						|
comment character, or if it is the last character on a line, extends
 | 
						|
a configuration directive across multiple lines.
 | 
						|
A
 | 
						|
.Dq #
 | 
						|
is the comment character, and all characters from it to the end of
 | 
						|
line are ignored (unless it is escaped with the escape character).
 | 
						|
.Pp
 | 
						|
The syntax of each line is:
 | 
						|
.Dl userglob[:groupglob][@host] [directive [class]]
 | 
						|
.Pp
 | 
						|
These elements are:
 | 
						|
.Bl -tag -width "groupglob" -offset indent
 | 
						|
.It Sy userglob
 | 
						|
matched against the user name, using
 | 
						|
.Xr fnmatch 3
 | 
						|
glob matching
 | 
						|
(e.g,
 | 
						|
.Sq f* ) .
 | 
						|
.It Sy groupglob
 | 
						|
matched against all the groups that the user is a member of, using
 | 
						|
.Xr fnmatch 3
 | 
						|
glob matching
 | 
						|
(e.g,
 | 
						|
.Sq *src ) .
 | 
						|
.It Sy host
 | 
						|
either a CIDR address (refer to
 | 
						|
.Xr inet_net_pton 3 )
 | 
						|
to match against the remote address
 | 
						|
(e.g,
 | 
						|
.Sq 1.2.3.4/24 ) ,
 | 
						|
or an
 | 
						|
.Xr fnmatch 3
 | 
						|
glob to match against the remote hostname
 | 
						|
(e.g,
 | 
						|
.Sq *.NetBSD.org ) .
 | 
						|
.It Sy directive
 | 
						|
If
 | 
						|
.Dq allow
 | 
						|
or
 | 
						|
.Dq yes
 | 
						|
the user is allowed access.
 | 
						|
If
 | 
						|
.Dq deny
 | 
						|
or
 | 
						|
.Dq no ,
 | 
						|
or
 | 
						|
.Sy directive
 | 
						|
is not given, the user is denied access.
 | 
						|
.It Sy class
 | 
						|
defines the class to use in
 | 
						|
.Xr ftpd.conf 5 .
 | 
						|
.El
 | 
						|
.Pp
 | 
						|
If
 | 
						|
.Sy class
 | 
						|
is not given, it defaults to one of the following:
 | 
						|
.Bl -tag -width "chroot" -offset indent
 | 
						|
.It Sy chroot
 | 
						|
If there is a match in
 | 
						|
.Sx /etc/ftpchroot
 | 
						|
for the user.
 | 
						|
.It Sy guest
 | 
						|
If the user name is
 | 
						|
.Dq anonymous
 | 
						|
or
 | 
						|
.Sq ftp .
 | 
						|
.It Sy real
 | 
						|
If neither of the above is true.
 | 
						|
.El
 | 
						|
.Pp
 | 
						|
No further comparisons are attempted after the first successful match.
 | 
						|
If no match is found, the user is granted access.
 | 
						|
This syntax is backward-compatible with the old syntax.
 | 
						|
.Pp
 | 
						|
If a user requests a guest login, the
 | 
						|
.Xr ftpd 8
 | 
						|
server checks to see that
 | 
						|
both
 | 
						|
.Dq anonymous
 | 
						|
and
 | 
						|
.Dq ftp
 | 
						|
have access, so if you deny all users by default, you will need to add both
 | 
						|
.Dq "anonymous allow"
 | 
						|
and
 | 
						|
.Dq "ftp allow"
 | 
						|
to
 | 
						|
.Pa /etc/ftpusers
 | 
						|
in order to allow guest logins.
 | 
						|
.Ss /etc/ftpchroot
 | 
						|
The file
 | 
						|
.Pa /etc/ftpchroot
 | 
						|
is used to determine which users will have their session's root directory
 | 
						|
changed (using
 | 
						|
.Xr chroot 2 ) ,
 | 
						|
either to the directory specified in the
 | 
						|
.Xr ftpd.conf 5
 | 
						|
.Sy chroot
 | 
						|
directive (if set),
 | 
						|
or to the home directory of the user.
 | 
						|
If the file does not exist, the root directory change is not performed.
 | 
						|
.Pp
 | 
						|
The syntax is similar to
 | 
						|
.Nm ,
 | 
						|
except that the
 | 
						|
.Sy class
 | 
						|
argument is ignored.
 | 
						|
If there's a positive match, the session's root directory is changed.
 | 
						|
No further comparisons are attempted after the first successful match.
 | 
						|
This syntax is backward-compatible with the old syntax.
 | 
						|
.Sh FILES
 | 
						|
.Bl -tag -width /usr/share/examples/ftpd/ftpusers -compact
 | 
						|
.It Pa /etc/ftpchroot
 | 
						|
List of normal users who should have their ftp session's root directory
 | 
						|
changed by using
 | 
						|
.Xr chroot 2 .
 | 
						|
.It Pa /etc/ftpusers
 | 
						|
This file.
 | 
						|
.It Pa /usr/share/examples/ftpd/ftpusers
 | 
						|
A sample
 | 
						|
.Nm
 | 
						|
file.
 | 
						|
.El
 | 
						|
.Sh SEE ALSO
 | 
						|
.Xr fnmatch 3 ,
 | 
						|
.Xr inet_net_pton 3 ,
 | 
						|
.Xr ftpd.conf 5 ,
 | 
						|
.Xr ftpd 8
 |