PAM_AUTHENTICATE(3PAM) PAM Library Functions PAM_AUTHENTICATE(3PAM)
NAME
pam_authenticate - perform authentication within the PAM framework
SYNOPSIS
cc [
flag ... ]
file ...
-lpam [
library ... ]
#include <security/pam_appl.h>
int pam_authenticate(
pam_handle_t *pamh,
int flags);
DESCRIPTION
The
pam_authenticate() function is called to authenticate the current
user. The user is usually required to enter a password or similar
authentication token depending upon the authentication service
configured within the system. The user in question should have been
specified by a prior call to
pam_start() or
pam_set_item().
The following flags may be set in the
flags field:
PAM_SILENT Authentication service should not
generate any messages.
PAM_DISALLOW_NULL_AUTHTOK The authentication service should return
PAM_AUTH_ERR if the user has a null
authentication token.
RETURN VALUES
Upon successful completion,
PAM_SUCCESS is returned. In addition to
the error return values described in
pam(3PAM), the following values
may be returned:
PAM_AUTH_ERR Authentication failure.
PAM_CRED_INSUFFICIENT Cannot access authentication data due to
insufficient credentials.
PAM_AUTHINFO_UNAVAIL Underlying authentication service cannot
retrieve authentication information.
PAM_USER_UNKNOWN User not known to the underlying
authentication module.
PAM_MAXTRIES An authentication service has maintained a
retry count which has been reached. No
further retries should be attempted.
ATTRIBUTES
See
attributes(7) for description of the following attributes:
+--------------------+-------------------------+
| ATTRIBUTE TYPE | ATTRIBUTE VALUE |
+--------------------+-------------------------+
|Interface Stability | Stable |
+--------------------+-------------------------+
|MT-Level | MT-Safe with exceptions |
+--------------------+-------------------------+
SEE ALSO
libpam(3LIB),
pam(3PAM),
pam_open_session(3PAM),
pam_set_item(3PAM),
pam_setcred(3PAM),
pam_start(3PAM),
attributes(7)NOTES
In the case of authentication failures due to an incorrect username
or password, it is the responsibility of the application to retry
pam_authenticate() and to maintain the retry count. An authentication
service module may implement an internal retry count and return an
error
PAM_MAXTRIES if the module does not want the application to
retry.
If the
PAM framework cannot load the authentication module, then it
will return
PAM_ABORT. This indicates a serious failure, and the
application should not attempt to retry the authentication.
For security reasons, the location of authentication failures is
hidden from the user. Thus, if several authentication services are
stacked and a single service fails,
pam_authenticate() requires that
the user re-authenticate each of the services.
A null authentication token in the authentication database will
result in successful authentication unless
PAM_DISALLOW_NULL_AUTHTOK was specified. In such cases, there will be no prompt to the user to
enter an authentication token.
The interfaces in
libpam are MT-Safe only if each thread within the
multithreaded application uses its own
PAM handle.
January 27, 2005 PAM_AUTHENTICATE(3PAM)