| -------------------------------------------------------------------------------- $Id: proftpdfaq.sgml,v 1.13 2001/02/21 19:44:49 flyhmstr Exp $ This document sets out many of the FAQs related to the installation, functioning and configuration of ProFTPD. It also provides some guidance on policy and security issues.
 --------------------------------------------------------------------------------
 1. Introduction to ProFTPD
 2. Compilation and installing  3. Compatibility and Integration  4. Common Running problems  5. Configuration problems  6. Security  7. User Authentication  8. Hamster droppings  9. FAQ Notes  1. Introduction to ProFTPD 1.1 What is ProFTPD
 ProFTPD is a ftp server primarily written for the various unix variants though it will now compile under win32. It has been designed to be much like Apache in concept taking many of the ideas (configuration format, modular design, etc) from it.
 1.2 What is the current version?  Stable: 1.2.1 Unstable: None
 1.3 Who codes/maintains it As with all Open source projects no one person can really lay claim to the entire package. The ProFTPD project was started by Floody who took it to approximately 1.2.0pre2/3 before he found that his available time was insufficient to handle this project as well as his other commitments. Since then (mid-late 1999) MacGyver has taken over the project and is pushing towards cleaning up the outstanding patches and getting 1.2.0 shipped.
 As of early 2001 Floody is back on the team and we are actively pushing for 1.2.0-release, this is expected before the end of March 2001  There are also numerous people involved in developing modules, and documentation for the project. A number of these have been merged into the core distribution and more are likely to follow.  1.4 Version numbering scheme At the moment there is a little irrationality in the numbering scheme however it can be summarised as follows
 1.0.x This is the previous stable version.
 1.1.x Development code
 1.2.0prex Pre-release testing versions, development code.
 1.2.0rcx Release candidate code, these releases are pretty much bug free and are testing releases prior to the final stable code.
 1.2.x This will be the stable cycle with the final .x being the incremental patches to fix bugs discovered after the release version is issued.
 1.3.x Once 1.2.0 is released onward development will start with 1.3.0 much like the Linux Kernel numbering cycle.
 1.5 Website & documentation http://www.proftpd.org/ is now online and contains copies of this FAQ, other documentation resources and information on the project. The documentation is being brought back into shape at the moment, the configuration on the website is now approaching where it should be but more work is required and is ongoing. There is also a mirror at http://proftpd.vom.tm/ and the documentation is also availible on http://pdd.sourceforge.net/
 Helping with documentation Writing documentation is a little time consuming and requires some work but it's not actually difficult. Get the source code from CVS, run "ShowUndocumented" in the doc directory. This will list what needs work. Grep through the code in the looking for something like
   --------------------------------------------------------------------------------  CHECK_CONF(cmd,CONF_ROOT|CONF_VIRTUAL|CONF_ANON|CONF_GLOBAL)  --------------------------------------------------------------------------------
 to figure out where the directive is valid (server config, , , for the above example). Once you think you understand what it does, test, play, break (if possible). Then copy the format in Configuration.html and add the new documentation.
 Once the documentation is complete run  cvs diff -uw Configuration.html > Configuration.html.patch
 and send it to [email protected] and the devel list.
 1.6 Bug reporting? Bug reports should be made via http://bugs.proftpd.org/ which uses the bugzilla tracking system. Patches should be mailed to the ProFTPD-Devel mailing list or MacGyver directly.
 1.7 I've found a security hole Please report all security problems with the code to [email protected] before releasing the information into the public domain. It would be appreciated if you give the core team a few days to put together a patch and/or new release to address the issue.
 Please adhere to the proceedures and timescales given in the RF Policy document http://www.wiretrip.net/rfp/policy.html, this will give the core development team a chance to get a fix or workaround in place before the problem becomes fully public domain.  1.8 Downloading There are two main methods of getting the software. Downloading a compressed tarball or rpm (there is also a Debian package available in the main distribution) from proftpd.org or from a mirror site, alternatively if you wish to run the latest bleeding edge code then collecting from the cvs server is the best method.
 Mirror sites There is a complete and maintained list of ftp mirror sites available from http://www.proftpd.org/download.html
 CVS CVS: cvs -d :pserver:[email protected]:/var/proftpd login (password is proftpd)
 Then do:  cvs -d :pserver:[email protected]:/var/proftpd checkout proftpd-1.2  To obtain the latest/greatest updates, just hop into the proftpd-1.2 directory and do: cvs update  A couple of sites generate downloadable tarballs of the latest CVS code to make obtaining the test code easier.  1.9 Mailing lists There are three lists for ProFTPD
 Announce [email protected]
 This is a very low traffic list where only ProFTPD announcements/changes will be announced.  Subscribe by sending a message to [email protected] with "subscribe" in the subject.  Users [email protected]
 This is intended to the the user support channel for the software, in most likelihood this is going to be a high traffic list and slightly chatty. Please read the FAQ, the documentation and the list archives before posting a question.  Subscribe by sending a message to [email protected] with "subscribe" in the subject.  Development [email protected]
 This list is intended for discussion of development-related issues of ProFTPD, and feature design. It is NOT intended to be a 'user help' group.  Subscribe by sending a message to [email protected] with 'subscribe' in the subject.  Archives The mailing list archives can be found at http://www.proftpd.org/proftpd-l-archive/ http://www.proftpd.org/proftpd-devel-archive/
 1.10 Copyright Issues The software is currently distributed under the GNU General Public License (version 2 or later) as published by the Free Software Foundation. Copyright is held by Public Flood Software.
 2. Compilation and installing
 2.1 What platforms will it compile on?
 There have been reports of ProFTPD compiling on all the following platforms (and versions).
 Linux 2.0.x & 2.2.x (glibc 2.x only) & 2.4.x
 BSDI 3.1 & 4.0
 IRIX 6.2, 6.3, 6.4, 6.5
 Solaris 2.5.1, 2.6 & 2.7
 AIX 3.2 & 4.2
 OpenBSD 2.2/2.3
 FreeBSD 2.2.7
 Digital UNIX 4.0A
 DEC OFS/1
 Why not libc5 on Linux? There are several known problems with libc5-based systems, including improperly implemented library routines (vsprintf and vsnprintf are examples). There are known problems with the resolver library. For these reasons and others lib5 is not being supported at all, the latest versions of the major distributions (inc Debian, Redhat and Suse) are all glibc.
 2.2 CVS CVS (Concurrent Versions System), is a version control system which allows multiple developers (scattered across the same room or across the world) to maintain a single codebase and keep a record of all changes to the work.
 The CVS repository for ProFTPD is available for non-developers in read-only mode, however this code is right on the bleeding edge and is not guaranteed to even compile let alone work. Access to CVS is given to allow important security patches out into the wild and to allow users and interested users to test out the latest changes on real systems.  Recommended /.cvsrc settings  cvs -z 3 update -Pd
 diff -uw
 Where can I get information on cvs?
 CVS is produced by Cyclic Software (http://www.cyclic.com/) and details on CVS can be found on their website. The CVS documentation is clear, detailed and above all heavy when printed. I'd recommend reading it if you're planning on using CVS a lot.
 2.3 How do I get debug output The easiest way is to fire up proftpd manually from the command line with the debug level cranked up.
 /usr/local/sbin/proftpd -d9 -n
 This will result in maximal debug output direct to the console. Warning, this can get messy on a busy server, for testing I would suggest copying the config and altering the port the server binds to and then testing.
 2.4 Patches Any patches should be submitted in Universal format, this makes integrating them into the main cvs source a lot easier. When generating a diff against the current cvs source use "cvs diff -uw" to generate the patch.
 cvs diff -uw filename > filename.patch
 or  cvs diff -uw > bigger.patch  Patches that add configuration directives without proper documentation. Will be rejected. New features without documentation are less than useless to the community at large.
 2.5 Using non-default modules Simply configure ProFTPD with
 ./configure --with-modules=mod_module1:mod_module2:mod_module3
 make
 make install
 2.6 Plans for next version (1.3.x)
 The new development series will be 1.3.x, using the same number scheme as the linux kernel developers. The targets/goals are:
 refining/redefining the module API to make it more extensible and useful.
 dynamic modules
 security APIs and implementations
 mod_ls rewrite
 Implementing some security-related RFCs
 Creating a web and GUI configuration interface to ProFTPD.
 2.0.x will be the production release of the 1.3.x development set.  2.7 NT Support If/when a port is undertaken for NT, it will only be after a near complete rethinking of ProFTPD. This is planned for 2.0 and onwards.
 2.8 New features/modules While anything new is welcomed it's probably better to at least float the idea first on the devel mailing list to ensure that someone else isn't already hacking on it. Also when submitting the patch or module for inclusion into the ProFTPD source full documentation is needed.
 Suggestions made for future development  GUI based configuration tool CDB based authentication
 3. Compatibility and Integration 3.1 SQL
 ProFTPD has support for authentication and logging via SQL databases using the mod_sql module as supplied in the main distribution.
 3.2 SSH Unfortunately while integration into ProFTPD itself might be possible it's pretty useless without the corresponding implementation within the commonly used ftp clients.
 3.3 sendfile() sendfile() is a system call which streamlines the copying of data between the disk and the tcp socket. The call copied from the page cache directly rather than requiring a kernel -> user space -> kernel space copy for every read() and write() call. Generally the advantages are only felt on heavily loaded servers. The call is supported in ProFTPD for Linux and FreeBSD.
 Linux 2.0.x sendfile is not supported under 2.0.x, this is not an issue when compiling for 2.0.x on a 2.0.x system. However when compiling on a 2.2.x system for use on 2.0.x use the --disable-sendfile flag.
 Runtime detection of sendfile() There are two patches available for runtime detection of sendfile() which gets round the 2.0.x problems.
 Johnie Ingram (aka netgod)'s: http://www.proftpd.org/proftpd-devel-archive/99-10/msg00073.html  John Pierce http://www.proftpd.org/proftpd-devel-archive/99-10/msg00112.html  What are these log lines in pre8? The pre8 code has some additional debug logging going on tracking how sendfile is working. Nothing to get excited about it's probably a case of MacGyver forgetting to comment it out.
 Problems with sendfile There appear to be a number of problems with sendfile() particularly with the directives and features which require accurate determination of filesize. Such as the Rate* functions and downloading large files, the best advice at the moment appears to be to disable sendfile by default ( --disable-sendfile ).
 Sendfile() also appears to be the source of a number of file corruption problems.  3.4 IPv6 There is currently no official support for IPv6 within the 1.2.x code tree, however there is an unofficial patch and more comprehensive support will probably be developed during the 1.3.x development cycle.
 3.5 Filename case sensitivity ProFTPD is utterly dependant on the underlying OS to handle filename case sensitivity. If the underlying OS is case sensitive then ProFTPD will be, there are currently no plans for a module to handle this.
 3.6 FXP FXP is capable of bouncing data between websites. There have been a number of reports of problems in configuring ProFTPD to function cleanly with this program (http://flashfxp.skuz.net/).
 To support FXP when connecting as a user place "AllowForeignAddress on" in the Global or VirtualHost context.  To support FXP when connecting as anon "AllowForeignAddress on" must be placed in the Anonymous context.  The config will happily support "AllowForeignAddress on" in multiple places within the config.  4. Common Running problems
 4.1 ProFTPD doesn't seem to work.
 Starting ProFTPD in standalone mode it doesn't show in 'ps' It could be many things, possibly something like not running ProFTPD as root (it needs to be run as root initially, but will switch to a non-privileged user). Regardless, ProFTPD logs all errors via the standard syslog mechanism. You need to check your system logs in order to determine what the problem is.
 It doesn't work! There are many times when there's a completely random problem which appears to be insoluble. The best place to ask for help is definately the mailing list (proftpd-l) but it's not productive to ask for help without giving enough information for intelligent debugging.
 Have you?  Checked your logs Tried the server in debug mode
 Read the FAQ?
 Checked the mailing list archive?
 Are you running the latest version?
 When posting try giving enough information, this might include but not be limited to.  OS and server version (proftpd -vv)
 List of included modules (proftpd -l)
 Appropriate log extracts
 Output fom debug mode
 Configration fragments
 4.2 "inet_create_connection() failed: Operation not permitted". You aren't starting ProFTPD as root, or you have inetd configured to run ProFTPD as a user other than root. The ProFTPD daemon must be started as root in order to bind to tcp ports lower than 1024, or to open your shadow password file when authenticating users. The daemon switches uid/gids to the user and group specified by the User/Group directives during normal operation, so a `ps' will show it running as the user you specified.
 4.3 Unable to bind to port/Address already in use You've configured ProFTPD to run as standalone, but you've left the line for the ftp service in /etc/inetd.conf. Comment out the line starting "ftp" in /etc/inetd.conf and restart (killall -HUP inetd or something similar should do the trick) and try again. Alternatively check to see if there's another copy of ProFTPD is running.
 4.4 "Fatal: Socket operation on non-socket" You have ProFTPD configured to run in inetd mode rather than standalone. In this mode, ProFTPD expects that it will be run from the inetd super-server, which implies that stdin/stdout will be sockets instead of terminals. As a result, socket operations will fail and the above error will be printed. If you wish to run ProFTPD from the shell, in standalone mode, you'll need to modify your proftpd.conf configuration file and add or edit the ServerType directive to read:
 ServerType standalone
 4.5 "Fatal: unable to determine IP address of 'hostname'"
 The hosting machine has a poorly configured hostname setup to the point where the resolver library cannot determine the IP from the name. Solutions include, fixing the DNS for the domain, fixing the hostname, fixing the /etc/hosts file. Which one works for you will largely depend on your OS and exactly what is wrong.
 4.6 I'm having problems with FTP clients behind firewalls The FTP Specification defines that two sockets should be used for all communications. The first runs over port 21 and is the control channel over which all commands and response codes are sent. Whenever data is required to be transfered, for example for a file download, a directory listing etc etc. A second channel is created on demand, this socket can take one of two forms.
 non-Passive The server end of the data socket uses port 20. This is nice and easy to work into a firewall configuration.
 Passive The port at either end is dynamically allocated. This is virtually impossible to cater for in a firewall configuration given that the port mapping will be different for every data connection.
 The solution is to force the users to configure their clients to use the non-passive mode (ie port 20)  4.7 Can I run more that one VirtualHost on a single IP? No, or at least not in the HTTP/1.1 manner of virtual hosting. This is an inbuilt limitation of the current FTP RFC., unlike the HTTP/1.1 spec there is no mechanism comparable to the "Host: foo.bar.com" HTTP header for specifying which host the connection is for. Therefore the only method for determining which VirtualHost the connection is destined for is by the destination IP.
 The one exception to this is if you host multiple servers on the same IP but using different ports, however this requires that the connecting client uses a non-standard port and therefore is probably not a good solution for mass hosting.  Is there anything in the pipeline to fix this? There is a draft standard draft standard with the IETF which extends and improves on the FTP specification including support for a HOST command. However given that the IP crunch is coming from websites and not virtual ftp servers this is unlikely to be pushed through any time soon.
 4.8 How do I run ProFTPD from inetd? Find the line in /etc/inetd.conf that looks something like this:
 ftp stream tcp nowait root in.ftpd in.ftpd  Replace it with:  ftp stream tcp nowait root in.proftpd in.proftpd  Then, find your inetd process in the process listing and send it the SIGHUP signal so that it will rehash and reconfigure itself. You may also need to add in.ProFTPD to hosts.allow on your system.  4.9 Can I use tcp-wrappers with ProFTPD? Yup. Although ProFTPD has built-in IP access control (see the Deny and Allow directives), many admins choose to consolidate IP access control in one place via in.tcpd. Just configure ProFTPD to run from inetd as any other tcp-wrapper wrapped daemon and add the appropriate lines to hosts.allow/deny files.
 4.10 Can I run an FTP server on a non-standard port? Yes. Use a block with your machine's FQDN (Fully Qualified Domain Name) or IP address, and a Port directive inside the block. For example, if your host is named "myhost.mydomain.com" and you want to run an additional FTP server on port 2001, you would:
   --------------------------------------------------------------------------------  ...  Port 2001 ...
   --------------------------------------------------------------------------------  4.11 Can control upload/download ratios?
 Yes the mod_ratio module provides for doing just this.
 The ratio directives take four numbers: file ratio, initial file credit, byte ratio, and initial byte credit. Setting either ratio to 0 disables that check.  The directives are HostRatio (matches FQDN, wildcards allowed), AnonRatio (matches password entered at login), UserRatio (accepts "*" for 'any user'), and GroupRatio.    --------------------------------------------------------------------------------  Ratios on # enable module UserRatio ftp 0 0 0 0
 HostRatio master.debian.org 0 0 0 0 # leech access (default)
 GroupRatio proftpd 100 10 5 100000 # 100:1 files, 10 file cred
 5:1 bytes, 100k byte cred
 AnonRatio [email protected] 1 0 1 0 # 1:1 ratio, no credits
 UserRatio * 5 5 5 50000 # special default case
 --------------------------------------------------------------------------------
 This example is for someone who (1) has downloaded 1 file of 82k, (2) has uploaded nothing, (3) has a ratio of 5:1 files and 5:1 bytes, (4) has 4 files and 17k credit remaining, and (5) is now changing directory to /art/nudes/young/carla. The initial credit, not shown, was 5 files and 100k (UserRatio * 5 5 5 100000).
 Version 2.0 and above of this module integrate with mod_sql.  Limitations of mod_ratio It appears that the ratio limits in mod_ratio are only maintained on a per session basis and there is no ongoing tracking of usage.
 4.12 Slow logins This is probably caused by a firewall or DNS timeout. By default ProFTPD will try to do both DNS and ident lookups against the incoming connection. If these are blocked or excessively delayed a slower than normal login will result. To turn off DNS and ident use:
   --------------------------------------------------------------------------------  UseReverseDNS off IdentLookups off
 --------------------------------------------------------------------------------
 IdentLookups and tcpwrappers***
 4.13 Lots of "FTP session closed" messages
 Oct 7 12:30:48 salvage2 proftpd[8874]: FTP session closed. Oct 7 12:30:48 salvage2 proftpd[8874]: FTP session closed.
 Oct 7 12:30:48 salvage2 proftpd[8874]: FTP session closed.
 Oct 7 12:30:48 salvage2 proftpd[8874]: FTP session closed.
 The above log extract is likely to be caused by a local monitoring system or a particularly aggressive DoS attack. Most service monitoring systems try opening the ftp port on the target server to detect whether it is active and running. Most of the time these tests are followed by an immediate "QUIT" or disconnection.
 TCPdump/TCPshow on the server in question should show which machine on your network is is generating these connections.  4.14 How do I see who is connected? The ftpwho command lists the state of each ftp connection to the server and what it's current activity is. However this does not detail the connection information on a virtual by virtual basis.
 4.15 Can I force ProFTPD to listen on only one IP? Sort, of it's not quite as clean as the socket binding under Apache but the principle works something like this.
 Standalone mode  To listen on the primary IP of a host Use the SocketBindTight directive
 To listen on a interfaces which are not the primary host interface Use the SocketBindTight directive, place your server configuration in a block and use "Port 0" for the main host configuration and and "Port 21" inside the VirtualHost block.
 inetd
 There are two approaches possible, the first is to use the patch from Daniel Roesen (check the mailing list archives).
 The second method is to run ProFTPD from xinetd (http://synack.net/xinetd/), a more advanced replacement of inetd. An entry for this in xinetd.conf would be something like this:    --------------------------------------------------------------------------------  service ftp {
 flags = REUSE
 socket_type = stream
 instances = 50
 wait = no
 user = root
 server = /usr/sbin/proftpd
 bind =
 log_on_success = HOST PID
 log_on_failure = HOST RECORD
 }
 --------------------------------------------------------------------------------
 4.16 "FTP server shut down ... please try again later."
 Check for /etc/shutmsg and delete it.
 4.17 How do I shutdown the server without killing proftpd? ftpshut, allows the server to disallow connections with a message without actually taking down the service. The shutdown can be scheduled for a point in the future or right now, existing connections can be allowed to finish, or be terminated now. Re-enabling is done by removing the /etc/shutmsg file.
 4.18 Is is possible to shutdown a single VirtualHost? No, the shutmsg file works at a daemon level not at a virtual host level.
 4.19 Error 421 This appears to be a general catch all error code meaning 'something nasty has gone wrong'.
 Connection has timed out
 The DefaultRoot specified doesn't exist
 The parent server has been killed
 Check /etc/services
 Wrong permissions on the DefaultRoot
 You get the idea...  4.20 proftpd doesn't show in the processlist Two possible reasons, first that it's simply not running, try proftpd -n -d2 to run in debug mode and see what happens. The other is that it's running from inetd and there are no active sessions at the moment.
 4.21 How do I restart/reload the server? This depends on the mode you're running the server in.
 Inetd Unless you're making a configuration change to inetd itself nothing needs doing. The server reloads the configuration everytime a new connection is made.
 Standalone Either stop and start the server completely (a little aggressive for most admin's tastes) or send a SIGHUP to the master daemon process.
 4.22 503 No PORT command issued A bug was introduced in 1.2.0rc2 which prevented the PORT command working properly and therefore breaking the data socket under certain conditions. The bug was documented as bug 240 and has been fixed in CVS. A rc3 release is due before the end of Jan 2001.
 4.23 Fatal: unable to determine IP address of Proftpd was unable to work out what IP is associated with the hostname in the VirtualHost block. Normally caused by a problem with the DNS resolution of the host, check the resolv.conf file and that your chosen nameservers are functional.
 4.24 451 append/restart not permitted, try again AllowStoreRestart is disabled by default because it will allow any writable file to be corrupted by a malicious user. It is recommended that this option is only used with authenticated users and then only in certain directories.
 4.25 The time being displayed is wrong The default behaviour for ProFTPD is to display all times relative to GMT. To use local time set "TimesGMT off" in the server section of the config. There is a known issue with Redhat 7, with regard to time handling. http://www.redhat.com/support/errata/rh7-errata-bugfixes.html
 4.26 Authentication is taking too long Make sure that ReverseDNS is disabled, turn off ident lookups. Additionally check the size of your /etc/passwd (or shadow) file, if it is large then the only solution may be to move to another authentication scheme.
 4.27 Corrupted files There appear to be some problems with both the use of sendfile() in ProFTPD and with the implementation within certain operating systems.
 4.28 Can I upgrade ProFTPD without terminating the current sessions? Short answer, no. Longer answer is no, but you can minimise the effects. The cleanest approach on servers which have significant amounts of traffic appears to be to use ftpshut to block new connections and terminate existing ones after a pre-determined time period and then to upgrade and restart. This approach limits the number of downloads which are terminated part way through.
 5. Configuration problems
 Problems encountered in trying to make the server behave exactly as required after compilation and installation are complete and the server is running.
 5.1 How do I add another anonymous login or guest account? You should look in the sample-configurations/ directory from your distribution tarball. Basically, you'll need to create another user on your system for the guest/anonymous ftp login. For security reasons, it's very important that you make sure the user account either has a password or has an "unmatchable" password. The root directory of the guest/anonymous account doesn't have to be the user's directory, but it makes sense to do so. After you have created the account, put something like the following in your /etc/proftpd.conf file (assuming the new user/group name is private/private):
   --------------------------------------------------------------------------------  AnonRequirePassword off
 User private
 Group private
 RequireValidShell off
 DenyAll
     --------------------------------------------------------------------------------  This will allow ftp clients to login to your site with the username "private" and their e-mail address as a password. You can change the AnonRequirePassword directive to "on" if you want clients to be forced to transmit the correct password for the 'private' account. This sample configuration allows clients to change into, list and read all directories, but denies write access of any kind.
 5.2 How do I ftp as root? First off this is a bad idea ftping as root is insecure, there are better more secure ways of shifting files as root.
 To enable root ftp ensure that the directive "RootLogin on" is included in your configuration.  5.3 How do I provide a secure upload facility? The following snippet from a sample configuration file illustrates how to protect an "upload" directory in such a fashion (which is a very good idea if you don't want people using your site for "warez"):
   --------------------------------------------------------------------------------  # All files uploaded are set to username.usergroup ownership
 User username
 Group usergroup
 UserAlias ftp username
 AuthAliasOnly on
 RequireValidShell off
   AllowAll  DenyAll
     --------------------------------------------------------------------------------  This denies all write operations to the anonymous root directory and sub-directories, except "incoming/" where the permissions are reversed and the client can store but not read. If you used instead of on , ftp clients would be allowed to perform all write operations to the sub-dir, including deleting, renaming and creating directories.
 5.4 How can I stop my users from using their space as a warez repository The above fragment will control anonymous users however if a local user with a full account with up and download capability is abusing their space then the technical measures which can be taken are limited. Applying a sane system quota is a good start, using the mod_quota and mod_ratio modules may control the rates of upload/download making it less useful as a warez repository. In the end it comes down to system monitoring and good site AUP's and enforcement.
 5.5 Can I rotate files out of an upload directory after upload? Yes. You'll need to write a script which either checks the contents of the directory regularly and moves once it's detected no size change in a file for xyz seconds. Or a script which monitors an upload log. There is no automatic method for doing this.
 5.6 How can I hide a directory from anonymous clients. Use the HideUser or HideGroup directive in combination with the proper user/group ownership on the directive. For example, if you have the follow directory in your anonymous ftp directory tree:
 drwxrwxr-x 3 ftp staff 6144 Apr 21 16:40 private
 You can use a directive such as "HideGroup staff" to hide the private directory from a directory listing. For example:
   --------------------------------------------------------------------------------  ...
 HideGroup staff  ...    --------------------------------------------------------------------------------  5.7 File/Directory hiding isn't working for me!
 You need to make sure that the group you are hiding isn't the anonymous ftp user's primary group, or HideGroup won't apply.
 5.8 I want to prevent users from accessing a hidden directory You can either change the permissions on the directory to prevent the anonymous FTP user from accessing it, or if you want to make it appear completely invisible (as though there is no such directory), use the IgnoreHidden directive inside a block for one or more commands that you want to completely ignore the hidden directory entries (ignore = act as if the directory entry does not exist).
 5.9 How do I setup a virtual FTP server? You'll need to configure your host to be able to handle multiple IP addresses. This is often called "aliasing", and can generally be configured through an IP alias or dummy interface. You need to read your operating system documentation to figure out how to do this. Once your have the host configured to accept the additional IP address that you wish to offer a virtual FTP server on, use the configuration directive to create the virtual server:
   --------------------------------------------------------------------------------  ServerName "My virtual FTP server"
   --------------------------------------------------------------------------------  You can add additional directive blocks into the block in order to create anonymous/guest logins and the like which are only available on the virtual host.
 5.10 I only want to allow anonymous access to a virtual server. Use a block to deny access at the top-level of the virtual host, then use again in your block to allow access to the anonymous login. This permits logins to a virtual anonymous server, but denies to everything else. Example:
   --------------------------------------------------------------------------------  ServerName "My virtual FTP server"
 DenyAll  User private
 Group private
 AllowAll  ...    --------------------------------------------------------------------------------
 5.11 How does work, and where should I use it?
 The directive is used to control connection or login access to a particular context (the directive block which contains it). When a client initially connects to ProFTPD, the daemon searches the configuration tree for directives, and attached parameters (such as Allow, Deny, etc). If it determines that there is no possible way for the client to ever be allowed to login, such as a "Deny from" matching the client's source address, without an overriding "Allow from" at a lower level, the client is disconnected without being offered the opportunity to transmit a user and password.
 However, if it is possible for the client to be allowed a login, ProFTPD continues as per normal, allowing the client to login only if the proper applies. Normally, directive blocks are allowed in the server config, , and contexts. However, should not be used in a context, as clients do not connect/login to a directory (and thus it is meaningless).  By way of example, the following configuration snippet illustrates a deny which will cause any incoming connections from the 10.1.1.x subnet to be immediately disconnected, without a welcome message:    --------------------------------------------------------------------------------  ...  Order deny,allow Deny from 10.1.1.
 Allow from all
 ...  --------------------------------------------------------------------------------
 Next, an example of a configuration using that will not immediately disconnect an incoming client, but will return "Login invalid" for all login attempts except anonymous.
   --------------------------------------------------------------------------------  ...  DenyAll  ...
 AllowAll  ...  --------------------------------------------------------------------------------
 5.12 How can I limit users to a particular directory tree?
 For general open access you can use an directive context block, possibly in combination with a UserPassword/AnonRequirePassword directive.
 However if you wish to jail an entire group (or groups) of users, you can use the DefaultRoot directive. DefaultRoot lets you specify a root jailed directory (or ' ' for the user's home directory), and an optional group-expression argument which can be used to control which groups of users the jail will be applied to. For example:    --------------------------------------------------------------------------------  ...  DefaultRoot ~ ...
 This creates a configuration where all users who log into myhost.mynet.foo are jailed into their home directories (cannot chdir
 into a higher level directory). Alternatively, you could:
 ...
 DefaultRoot /u2/public users,!staff ...
   --------------------------------------------------------------------------------  In this example, all users who are members of group 'users', but not members of group "staff" are jailed into /u2/public. If a user does not meet the group-expression requirements, they login as per normal (not jailed, default directory is their home). You can use multiple DefaultRoot directives to create multiple jails inside the same directive context. If two DefaultRoot directives apply to the same user, ProFTPD arbitrarily chooses one (based on how the configuration file was parsed).
 Security Implications The DefaultRoot directive is implemented using the chroot(2) system call. This moves the "/" (or root) directory to a specified point within the file system and jails the user into this sub-tree. However this is not the holy grail of security, a chroot jail can be broken, it is not a trivial matter but it's nowhere near impossible. DefaultRoot should be used as part of a general system of security not the only security measure.
 A more detailed discussion on this subject and on the breaking of chroot jails has been written by Simon Burr  Non-root server issues The chroot() system call will not work under a non-root ftp server process, the call requires root privaliges. Without them it simply doesn't work, there doesn't appear to be any checking in the code of the uid/gid before calling chroot so using DefaultRoot in such a setup will cause the server to fail.
 Symlinks Symlinks will not work from within a chrooted area. The reason should be clear from a casual inspection of the nature of the chroot command. It is not possible to have a symbolic link to a directory which can't be reached beacuse it's outside of the current chroot. Work arounds to allow access to other parts of the file system include exporting the part of the filesystem to be accessed from inside the chroot and mounting via NFS, using hard file links or (on Solaris) using lofs to mount the directory via the loopback.
 mount -Flofs /home/data1 /ftp/data1
 mount -Flofs /home/data2 /ftp/data2
 5.13 How do I create individual anonymous FTP sites for my users?
 There are two methods of accomplishing this (possibly more). First, you can create a directory structure inside your anonymous FTP root directory, creating a single directory for each user and setting ownership/permissions as appropriate. Then, either create a symlink from each user's home directory into the FTP site, or instruct your users on how to access their directory.
 The alternate method (and more versatile) of accomplishing per-user anonymous FTP is to use AnonymousGroup in combination with the DefaultRoot directory. You'll probably want to do this inside a , otherwise none of your users will be able to access your system without being stuck inside their per-user FTP site. Additionally, you'll want to use a deferred block to carefully limit outside access to each user's site.  Create a new unix group on your system named `anonftp'. Please each user who will have per-user anonymous FTP in this group.
 Create an `anon-ftp' and `anon-ftp/incoming' directory in each user's home directory.
 Modify your /etc/proftpd.conf file to look something like this (you'll probably want to customize this to your needs):
   --------------------------------------------------------------------------------    # the next line limits all logins to this virtual host, so that only anonftp users can connect
 DenyGroup !anonftp
 # limit access to each user's anon-ftp directory, we want read-only
 except on incoming
   DenyAll
   # permit stor access to each user's anon-ftp/incoming directory,
 but deny everything else
   AllowAll
 DenyAll
   # provide a default root for all logins to this virtual host.
 DefaultRoot ~/anon-ftp
 # Finally, force all logins to be anonymous for the anonftp group
 AnonymousGroup anonftp
   --------------------------------------------------------------------------------
 5.14 I want to support normal login and Anonymous under a particular user
 You can use the AuthAliasOnly directive to control how and where real usernames get authenticated (as opposed to aliased names, via the UserAlias directive). Note that it is still impossible to have two identical aliased names login to different anonymous sites; for that you would need .
 Example:    --------------------------------------------------------------------------------  ...  User jrluser
 Group jrluser
 UserAlias ftp jrluser
 UserAlias anonymous jrluser
 AuthAliasOnly on
 ...
   --------------------------------------------------------------------------------
 Here, the configuration for jrluser is set to allow alias authentication only. Thus, if a client attempts to authenticate as 'jrluser', the anonymous config will be ignored and the client will be authenticated as if they were a normal user (typically resulting in `jrluser' logging in normally). However, if the client uses the aliased username `ftp' or `anonymous', the anonymous block is applied.
 5.15 Why doesn't Anonymous ftp work (550 login incorrect)? Things to check Check the following first:
 Make sure the user/group you specified inside the block actually exists. This must be a real user and group, as it is used to control whom the daemon runs as and authenticates as.
 If RequireValidShell is not specifically turned off, make sure that your "ftp user" (as specified by the User directive inside an block), has a valid shell listed in /etc/shells. If you do not wish to give the user a valid shell, you can always use "RequireValidShell off" to disable this check.
 If UseFtpUsers is not specifically turned off, make sure that your "ftp user" is not listed in /etc/ftpusers.
 If all else fails, you should check your syslog. When authentication fails for any reason, ProFTPD uses the syslog mechanism to log the reason for failure; using the AUTH (or AUTHPRIV) facility. If you need further assistance, you can send email, including related syslog entries and your configuration file, to the ProFTPD mailing list mentioned elsewhere in this FAQ.  5.16 Bandwidth control The Bandwidth directive has been removed as of 1.2.0pre8, this directive acted on a per-virtual basis. It was generally held that it worked on the principle that a single connection to a given virtual could take the full bandwidth limit until other connections were made. However, the server uses either separate server (inetd) or forked (standalone) model there is no way for the various processes to communicate, therefore is no way they could share the bandwidth allocation.
 The replacement actually does the same but does it in a more rigorous manner and more precisely. The directives RateReadBPS, RateReadFreeBytes, RateReadHardBPS work by limiting on a per-connection basis.  Bandwidth 81920
 is replaced with something like  RateReadBPS 81920 RateReadFreeBytes 5120
 RateReadHardBPS on
 To achieve a total limit on a per virtual basis a mix of RateReadBPS and MaxClients is needed. ie RateReadBPS x MaxClients = Total Bandwidth allocation. There is no way (at the moment) to specify that virtual server xyz has a maximum total bandwidth of 200K/s that it can use between all connections.
 Per-virtual, per-user and global limits are currently in the "to be coded" pile and are being penciled in for the 1.3.x development series. There is some work in providing for a shared communication system between servers before this can happen.  Rate controls aren't working In pre9 and earlier Rate* does not work if sendfile is enabled, recompile with --without-sendfile and all should be as expected.
 5.17 CHMOD isn't working As of rc1 the AllowChmod command was added to allow control over who is allowed to use the CHMOD command. The default value for this directive is off.
 5.18 How can I limit the size of uploaded files? There is no way within ProFTPD itself to control how large a file can be uploaded. The best solution to this problem at the moment is to use whatever disk quota tools are available within your OS.
 6. Security 6.1 General
 Between versions 1.2.0pre3 - 1.2.0pre7 there were a number of buffer overflow type security problems with ProFTPD, with the coming release of pre7 these should be under control. Though no absolute statement can be given on the security of the software (this is true for every piece of software out there). A significant amount of effort has been put into removing the more 'dangerous' system calls which are prone to overflow attacks.
 Versions 1.2.0 should be considered to be production code and few if any new features will be added to this code branch to maintain stability.  What about using Stackguard? Stackguard is a gcc variant which can protect programs from stack-smashing attacks, programs compiled using Stackguard dies without executing the stack code. While this approach is a good first line of defense against future problems it's not a complete cure-all. Some of the buffer overflows were found on static variables, which are not protected by stack protection mechanisms.
 6.2 Surely running ProFTPD as non-root will help? Running ProFTPD as a non-root user gives only a marginal security improvement on the normal case and adds some functional problems. Such as not being able to bind to ports 20 or 21, unless it's spawned from inetd.
 ProFTPD takes a middle road in terms of security. It only uses root privileges where required and drops to the UID defined in the config file at all other times. Times when root is required include, binding to ports < 1024, setting resource limits, reading configuration information and some network code.  For Linux 2.2.x kernel systems there is the POSIX style mod_linuxprivs module which allows very fine grain control over privileges. This is highly recommended for security-conscious admins.  6.3 How can I control what commands the server accepts? Use a sane Allow/DenyFilter, these directives use regular expressions to control all text sent over the control socket. (If anyone has some good examples please let me know.)
 6.4 How can I prevent the server version from being displayed Setting SeverIdent to "off" should turn off the information about what type of server is running. To have maximum effect this directive should either be in the Global context or included in every virtual host block and the default block.
   --------------------------------------------------------------------------------  ServerIdent On "Linux.co.uk server"  ServerIdent Off  --------------------------------------------------------------------------------
 6.5 I want to show a message prior to login
 Use the DisplayConnect directive to specify a file containing a message to be displayed prior to login.
   --------------------------------------------------------------------------------  DisplayConnect /ftp/ftp.virtualhost/login.msg  --------------------------------------------------------------------------------
 6.6 I want to display a message after login
 Use the DisplayLogin directive, this sends a specified ASCII file to the connected user.
   --------------------------------------------------------------------------------  DisplayLogin /etc/proftp.msg  --------------------------------------------------------------------------------
 6.7 Can I have a custom welcome response?
 Use the AccessGrantMsg directive, this sends a simple single line message back to the user after a successful authentication. Magic cookies appear to be honoured in this directive.
   --------------------------------------------------------------------------------  AccessGrantMsg "Guest access granted for %u."  --------------------------------------------------------------------------------
 Note, this directive has an overriding default and needs to be specified in both VirtualHost and Anonymous blocks.
 6.8 External Programs ProFTPD has been designed to run as a secure ftp server, this means that it tries to keep as much as possible under it's control. An external program is a security risk in itself because it's behaviour is not controllable from within the ftpd code.
 7. User Authentication This section is being re-written due to major structural changes to the SQL module prior to 1.2.0
 7.1 Why is PAM the default authentication system? Security, pure and simple. PAM is the most secure (or securable) of the available authentication systems. Many of the issues and configuration hints for PAM are contained in README.PAM which is bundled with the server source and in the various packaged builds. To use /etc/passwd manual compilation will be required with the configure script being run with the --without-pam flag. Unless the PAM subsystem is properly configured authentication will fail.
 7.2 Authentication methods supported  PAM Standard /etc/passwd lookups
 NIS
 Shadow passwords
 Indvidual passwd/group files for each virtual
 SQL databases
 If these don't fit in with your system then writing a custom module or using such as the 'ld.so.preload' approach to intercept getpwbynam() system calls works happily with ProFTPD.  7.3 Problems with non-PAM authentication Generally these problems will be cured by either disabling PAM completely or by ensuring that these directives are set
   --------------------------------------------------------------------------------  PersistentPasswd off AuthPAMAuthoritative off
 --------------------------------------------------------------------------------
 7.4 AuthPAMAuthorative is an unknown directive!
 Check the spelling it should be AuthPAMAuthoritative not AuthPAMAuthorative or any other variation.
 7.5 Configuring PAM There is a README.Pam in the top directory of the ProFTPD install directory :
 Redhat Linux  --------------------------------------------------------------------------------
 #%PAM-1.0 auth required /lib/security/pam_listfile.so item=user
 sense=deny file=/etc/ftpusers onerr=succeed
 auth required /lib/security/pam_pwdb.so shadow nullok
 account required /lib/security/pam_pwdb.so
 session required /lib/security/pam_pwdb.so
 --------------------------------------------------------------------------------
 SuSE Linux
 SuSE appears to uses pam_unix rather than pam_pwdb which is the Redhat approach. All references to pam_pwdb should be replaced with "pam_unix" on SuSE systems.
 The following fragment is reported to work fine on SuSE 6.2    --------------------------------------------------------------------------------  /etc/pam.d/ftpd #%PAM-1.0
 # Uncomment this to achieve what used to be ftpd -A. # auth required /lib/security/pam_listfile.so item=user sense=allow file=/etc/ftpchroot onerr=fail
 auth required /lib/security/pam_listfile.so item=user sense=deny file=/etc/ftpusers onerr=succeed
 auth sufficient /lib/security/pam_ftp.so
 auth required /lib/security/pam_unix.so
 auth required /lib/security/pam_shells.so
 account required /lib/security/pam_unix.so
 password required /lib/security/pam_unix.so
 session required /lib/security/pam_unix.so
 --------------------------------------------------------------------------------
 FreeBSD
 FreeBSD does not support PAM session directives. If you remove the following line from the FreeBSD section of README.PAM, PAM should work properly under recent versions of FreeBSD.
   --------------------------------------------------------------------------------  ftp session required pam_unix.so try_first_pass  --------------------------------------------------------------------------------
 7.6 pam_sm_open_session errors
 ProFTPD requires PAM version 0.59 or better. pam_sm_open_session is not part of previous versions.
 7.7 Normal users can't login, only anon. Check that the /etc/pam.d/ftp file exists on the system and is configured as detailed in README.PAM
 7.8 AuthPAMAuthoritative Currently AuthPAMAuthoritative defaults on "ON" resulting in login failures if PAM cannot authenticate the user. This breaks the AuthUserFile directive as it never gets a chance to authenticate the user unless the AuthPAMAuthoritative directive is set to "OFF"
 The reasoning behind the current default is to ensure that the system is secure by default requiring that the admin explicitly and knowingly has to disable it. There are discussions underway which may result in the directive flipping to a default of "Off" if AuthUserFile is specified.  Note: as of the current CVS and the forthcoming pre9 release the default has changed to "Off"  7.9 LDAP mod_ldap is currently stable; there were a couple bugs that were squashed after release 1.0 of the module. it is still udner development , check the website for more information. There is an example config fragment on the author's site which gives a reasonable idea on how to use this module.
 7.10 Encrypted passwords There are patches which are being merged in at the moment to provide SHA encryption. The plan is to have the server get all user information except passwords via an anonymous bind. The server will then reconnect as a user is logging in and attempt to get the password via an encrypted connection. This should be in the next major release (2.5)
 7.11 SecureID No support yet
 7.12 One time passwords This is possible using either PAM or the Opie modules. The module passes back a challenge which the user puts into a key generator along with their 'pass phrase' and it gives them back 5 words which get sent as the password. As long as you do it correctly it will never repeat.
 It requires opie to be installed on the server. There are key gen clients for win95/98, *nix, mac.  ftp://ftp.urbanrage.com/pub/c/mod_opie.c  7.13 RADIUS Radius support isn't built into ProFTPD, though there's nothing stopping someone writing a module and submitting it for inclusion in the code tree. Possibly the easist way to implement Radius is by using the modules available for PAM and using the inbuilt PAM support.
 7.14 Anonymous password checking Is it possible to check an offered email address in an anonymous login before allowing access. Simple answer, not a hope in hell, anonymous access is pretty much designed to be freely open without checks and restrictions other than those placed on upload/download from the site. The best that can be hoped for is decent logging and tracking of accesses, and the requesting IP.
 7.15 Configuring for SQL authentication ith-modules=mod_sqlpw:mod_mysql  configure --with-modules=mod_sqlpw:mod_mysql Edit Make.rules
 Compile with: make
 Then install per the Proftpd instructions: make install
 Edit the proftpd configuration file/usr/local/etc/proftpd.conf
 Set up your system so libmysqlclient.so can be found
 Note the ordering of the modules in the configure command is significant, incorrect ordering will cause problems.  Edit Make.rules  Add the location of the MySQL include files to the CPPFLAGS in Make.rules: CPPFLAGS=$(DEFAULT_PATHS) $(PLATFORM) -I.. -I$(top_srcdir)/include -I/usr/local/mysql/include/mysql
 Add the location of the MySQL client library to the LDFLAGS in Make.rules:
 LDFLAGS=-L/home/builds/proftpd-1.2.0pre10/lib -L/usr/local/mysql/lib/mysql
 Add the MySQL client library to the LIBS variable so that it will be required at link time.
 LIBS=-lsupp -ldl -lcrypt -lm -lmysqlclient -lpam
 Edit the proftpd.conf file Make sure to add these lines and change where appropriate (example: the password)
   --------------------------------------------------------------------------------  --[ proftpd.conf ]-- # auth using mysql host login pass db
 MySQLInfo localhost hamster ***** proftpd
 SQLUserTable ftp
 SQLUsernameField username
 SQLUidField uid
 SQLGidField gid
 SQLPasswordField password
 SQLHomedirField homedir
 SQLLoginCountField count
 SQLAuthoritative on
 SQLPlaintextPasswords on
 --[ proftpd.conf ]--
 --------------------------------------------------------------------------------
 Set up your system so libmysqlclient.so can be found
 First decide how to do it: On Linux: make it system wide by editing /etc/ld.so.conf Modify the LD_LIBRARY_PATH for root, or in a shell wrapper script to proftpd. Note: if you have Linux and are not installing more than one version of MySQL use the edit ld.so.conf solution. Linux: Editing /etc/ld.so.conf, as root: Add the same path you added to LDFLAGS at the bottom of the file /usr/local/mysql/lib/mysql Run the ldconfig program. Note: there will be no visible sign that this has worked, it just will... Modify the LD_LIBRARY_PATH Add these lines to either root's .profile (or .bashrc) or to a shell script that is wrappering proftpd
   --------------------------------------------------------------------------------  if [ -z "$LD_LIBRARY_PATH" ] ; then export LD_LIBRARY_PATH="/usr/local/mysql/lib/mysql" else
 export LD_LIBRARY_PATH="/usr/local/mysql/lib/mysql:$LD_LIBRARY_PATH"
 --------------------------------------------------------------------------------
 Detailing how to use MySQL is outside the scope of this document, so here's some links.
 Administration
 Intro
 Quick rundown of what's needed to make a database  Create a user for proftpd to access the database as Create permissions for this user
 Create new database (mine is called proftpd)
 Reload as required to make this live
 Create a table within proftpd (mine is ftp)
 Creating a user  Connect to the MySQL access DB: mysql mysql Use Insert to the user you want proftpd to use to access the DB
 insert into user values ('%', 'hamster', password('mypasswd'),'Y','N','Y','N','N','N','N','N','N','N' ,'N','N','N','N');
 The above insert will work for MySQL v3.23.x, if you are using an older MySQL remove the last 4 'N'. Your User access table in MySQL v3.23.x should look like:    --------------------------------------------------------------------------------  +------+-----------+------------------+-------------+-------------+-------------+-------------+-------------+-----------+-------------+---------------+--------------+-----------+------------+-----------------+------------+------------+ | Host | User | Password | Select_priv | Insert_priv | Update_priv | Delete_priv | Create_priv | Drop_priv | Reload_priv | Shutdown_priv | Process_priv | File_priv | Grant_priv | References_priv | Index_priv | Alter_priv |
 +------+-----------+------------------+-------------+-------------+-------------+-------------+-------------+-----------+-------------+---------------+--------------+-----------+------------+-----------------+------------+------------+
 | % | hamster | 0d26d1e75ffa7efb | Y | N | Y | N | N | N | N | N | N | N | N | N | N | N |
 +------+-----------+------------------+-------------+-------------+-------------+-------------+-------------+-----------+-------------+---------------+--------------+-----------+------------+-----------------+------------+------------+
 --------------------------------------------------------------------------------
 Creating the DB
 Use the mysqladmin command to create the database: mysqladmin create proftpd
 Reloading and refreshing the MySQL daemon  Use the mysqladmin command to refresh and reload its DB pointers and configurations mysqlamdin refresh
 mysqlamdin reload
 Creating the Table  Copy the following SQL create statement to a file and run it. mysql proftpddb < table_create_file
   --------------------------------------------------------------------------------  #mysqldump proftpd ftp # MySQL dump 8.2
 #
 # Host: localhost Database: proftpd
 #--------------------------------------------------------
 # Server version 3.23.13a-alpha-log
 # # Table structure for table 'ftp'
 #
 CREATE TABLE ftp ( username varchar(60) binary,
 uid int(11),
 gid int(11),
 password varchar(30),
 homedir varchar(250),
 count int(11)
 );
 --------------------------------------------------------------------------------
 You may want to refresh and reload MySQL again, how to is listed above. What you should end up with is something that looks like this:
   --------------------------------------------------------------------------------  Database changed mysql> show tables;
 +-------------------+
 | Tables in proftpd |
 +-------------------+
 | ftp |
 +-------------------+
 1 row in set (0.02 sec)
 mysql> show columns from ftp ; +----------+--------------------+------+-----+---------+-------+---------------+
 | Field | Type | Null | Key | Default | Extra | Privileges |
 +----------+--------------------+------+-----+---------+-------+---------------+
 | username | varchar(60) binary | YES | | NULL | | select,update |
 | uid | int(11) | YES | | NULL | | select,update |
 | gid | int(11) | YES | | NULL | | select,update |
 | password | varchar(30) | YES | | NULL | | select,update |
 | homedir | varchar(250) | YES | | NULL | | select,update |
 | count | int(11) | YES | | NULL | | select,update |
 +----------+--------------------+------+-----+---------+-------+---------------+
 6 rows in set (0.00 sec)
 --------------------------------------------------------------------------------
 Note: in MySQL v3.23.x and above you will see a Privileges column, if you are running an older version, you will not see that.
 Database Permissions At the very least the user/host the profptd daemon uses to connect to the SQL server should have SELECT permission. If the "count" field is being used to track a users usage then UPDATE is also required. The lack of these permissions may cause the server to fail.
 Gotcha's  421 Service not availible Make sure that the home directory of the user concerned actually exists and has the right ownerships/permissions
 Can't connect to the database  Is it running? Is it listening?
 Does the user proftpd is using have the right permissions?
 7.16 Can I run the whole process in a chroot()?
 No, not at the moment, ProFTPD was not designed to run chrooted and needs access to various system files through out it's normal running lifetime. (/etc/passwd for example). -->
 8. Hamster droppings 8.1 Why...
 This chapter is not meant to be meaningful, it's where I cut and paster ideas, comments, code fragments before I work them into the main part of the document.
 8.2 Odds and ends Why can't I delete a directory with dele ?
 Port bouncing, ftp bouncing, priv ports  hiding dire 
  
 
 |