2 .\" Copyright (c) 2008, Sun Microsystems, Inc. All Rights Reserved.
3 .\" The contents of this file are subject to the terms of the Common Development and Distribution License (the "License"). You may not use this file except in compliance with the License.
4 .\" You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE or http://www.opensolaris.org/os/licensing. See the License for the specific language governing permissions and limitations under the License.
5 .\" When distributing Covered Code, include this CDDL HEADER in each file and include the License file at usr/src/OPENSOLARIS.LICENSE. If applicable, add the following below this CDDL HEADER, with the fields enclosed by brackets "[]" replaced with your own identifying information: Portions Copyright [yyyy] [name of copyright owner]
6 .TH PAM_UNIX_AUTH 5 "Apr 23, 2008"
8 pam_unix_auth \- PAM authentication module for UNIX
12 \fBpam_unix_auth.so.1\fR
18 The \fBpam_unix_auth\fR module implements \fBpam_sm_authenticate()\fR, which
19 provides functionality to the PAM authentication stack. It provides functions
20 that use \fBcrypt\fR(3C) to verify that the password contained in the \fBPAM\fR
21 item \fBPAM_AUTHTOK\fR is the correct password for the user specified in the
22 item \fBPAM_USER\fR. If \fBPAM_REPOSITORY\fR is specified, then user's password
23 is fetched from that repository. Otherwise, the default \fBnsswitch.conf\fR(4)
24 repository is searched for that user.
27 For accounts in the name services which support automatic account locking, the
28 account may be configured to be automatically locked (see \fBuser_attr\fR(4)
29 and \fBpolicy.conf\fR(4)) after multiple failed login attempts. For accounts
30 that are configured for automatic locking, if authentication failure is to be
31 returned, the failed login counter is incremented upon each failure. If the
32 number of successive failures equals or exceeds \fBRETRIES\fR as defined in
33 \fBlogin\fR(1), the account is locked and \fBPAM_MAXTRIES\fR is returned.
34 Currently, only the "files" repository (see \fBpasswd\fR(4) and
35 \fBshadow\fR(4)) supports automatic account locking. A successful
36 authentication by this module clears the failed login counter and reports the
37 number of failed attempts since the last successful authentication.
40 Authentication service modules must implement both \fBpam_sm_authenticate()\fR
41 and \fBpam_sm_setcred()\fR. To allow the authentication portion of UNIX
42 authentication to be replaced, \fBpam_sm_setcred()\fR in this module always
43 returns \fBPAM_IGNORE\fR. This module should be stacked with
44 \fBpam_unix_cred\fR(5) to ensure a successful return from
45 \fBpam_setcred\fR(3PAM).
48 The following options can be passed to the module:
56 Turn off warning messages.
62 \fB\fBserver_policy\fR\fR
66 If the account authority for the user, as specified by \fBPAM_USER\fR, is a
67 server, do not apply the UNIX policy from the \fBpasswd\fR entry in the name
78 Regardless of the automatic account locking setting for the account, do not
79 lock the account, increment or clear the failed login count. The \fBnolock\fR
80 option allows for exempting account locking on a per service basis.
86 The following error codes are returned from \fBpam_sm_authenticate()\fR:
90 \fB\fBPAM_AUTH_ERR\fR\fR
94 Authentication failure.
100 \fB\fBPAM_BUF_ERR\fR\fR
110 \fB\fBPAM_IGNORE\fR\fR
114 Ignores module, not participating in result.
120 \fB\fBPAM_MAXTRIES\fR\fR
124 Maximum number of retries exceeded.
130 \fB\fBPAM_PERM_DENIED\fR\fR
140 \fB\fBPAM_SUCCESS\fR\fR
144 Successfully obtains authentication token.
150 \fB\fBPAM_SYSTEM_ERR\fR\fR
160 \fB\fBPAM_USER_UNKNOWN\fR\fR
164 No account present for user.
169 The following error codes are returned from \fBpam_sm_setcred()\fR:
173 \fB\fBPAM_IGNORE\fR\fR
177 Ignores this module regardless of the control flag.
183 See \fBattributes\fR(5) for descriptions of the following attributes:
191 ATTRIBUTE TYPE ATTRIBUTE VALUE
193 Interface Stability Committed
195 MT Level MT-Safe with exceptions
201 \fBlogin\fR(1), \fBpasswd\fR(1), \fBuseradd\fR(1M), \fBusermod\fR(1M),
202 \fBroleadd\fR(1M), \fBrolemod\fR(1M), \fBcrypt\fR(3C), \fBlibpam\fR(3LIB),
203 \fBpam\fR(3PAM), \fBpam_authenticate\fR(3PAM), \fBpam_setcred\fR(3PAM),
204 \fBsyslog\fR(3C), \fBpam.conf\fR(4), \fBpasswd\fR(4), \fBpolicy.conf\fR(4),
205 \fBnsswitch.conf\fR(4), \fBshadow\fR(4), \fBuser_attr\fR(4),
206 \fBattributes\fR(5), \fBpam_authtok_check\fR(5), \fBpam_authtok_get\fR(5),
207 \fBpam_authtok_store\fR(5), \fBpam_dhkeys\fR(5), \fBpam_passwd_auth\fR(5),
208 \fBpam_unix_account\fR(5), \fBpam_unix_session\fR(5)
212 The interfaces in \fBlibpam\fR(3LIB) are MT-Safe only if each thread within the
213 multi-threaded application uses its own \fBPAM\fR handle.
216 The \fBpam_unix\fR(5) module is no longer supported. Similar functionality is
217 provided by \fBpam_authtok_check\fR(5), \fBpam_authtok_get\fR(5),
218 \fBpam_authtok_store\fR(5), \fBpam_dhkeys\fR(5),
219 \fBpam_passwd_auth\fR(5),\fBpam_setcred\fR(3PAM), \fBpam_unix_account\fR(5),
220 \fBpam_unix_cred\fR(5), \fBpam_unix_session\fR(5).
223 If the \fBPAM_REPOSITORY\fR \fIitem_type\fR is set and a service module does
224 not recognize the type, the service module does not process any information,
225 and returns \fBPAM_IGNORE\fR. If the \fBPAM_REPOSITORY\fR \fIitem_type\fR is
226 not set, a service module performs its default action.