mod_auth_pam
PAM stands for Pluggable Authentication Modules,
and is used to configure ways for authenticating users.  Now
"authenticating" a user usually means comparing a password they
give with some other information, and returning a "yes/no"-style
answer.  PAM does not provide all of the other information for a user,
such as UID, GID, home, and shell.  This means that mod_auth_pam
cannot be used, by itself, as an auth module for proftpd;
mod_auth_pam is used to supplement other auth modules by
providing access to PAM's additional authentication checks.
Installation instructions for mod_auth_pam can be found
here.
The most current version of mod_auth_pam is distributed in the
ProFTPD source distribution.
<VirtualHost>, <Global>
The AuthPAM directive enables or disables the module's runtime
PAM check.  If it is set to off this module does not consult PAM
when authenticating a user.
<VirtualHost>, <Global>
The AuthPAMConfig directive is used to specify the name of
the service used when performing the PAM check; PAM configurations can
vary depending on the service.  By default, the "ftp" service
is used.  Note that on some platforms, e.g. FreeBSD, this may
need to be set to "ftpd", depending on the PAM configuration
involved.
Here's an example of changing the service used:
  <IfModule mod_auth_pam.c>
    AuthPAMConfig ftpd
  </IfModule>
<VirtualHost>, <Global>
The AuthPAMOptions directive is used to configure various optional
behavior of mod_auth_pam.
Example:
  <IfModule mod_auth_pam.c>
    # Do not set the PAM_TTY token when authenticating via PAM
    AuthPAMOptions NoTTY
  </IfModule>
The currently implemented options are:
NoTTY
    By default, mod_auth_pam will use the PAM_TTY
    PAM API item, and will use a value of "/dev/ftpdPID".  The item
    can be used by PAM modules for filtering access, for example.  This
    "NoTTY" option tells mod_auth_pam to not set the
    PAM_TTY item.
    
    Note: On Solaris platforms, the use of this PAM_TTY
    token is mandatory, and cannot be disabled.  This is due to 
    Solaris Bug ID 4250887.
  
mod_auth_pam module is automatically included when
proftpd is built on a system that supports PAM. To disable
this automatic inclusion, use the --disable-auth-pam configure
option.