Change pam_get_authtok()'s prototype so the caller can specify

what token it wants.  Also introduce PAM_OLDAUTHTOK_PROMPT.

Sponsored by:	DARPA, NAI Labs


git-svn-id: svn+ssh://svn.openpam.org/svn/openpam/trunk@100 185d5e19-27fe-0310-9dcf-9bff6b9f3609
This commit is contained in:
Dag-Erling Smørgrav 2002-04-06 17:05:21 +00:00
parent 6a52d30938
commit 1eafe40ac3
5 changed files with 64 additions and 14 deletions

View file

@ -31,7 +31,7 @@
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE. * SUCH DAMAGE.
* *
* $P4: //depot/projects/openpam/include/security/openpam.h#12 $ * $P4: //depot/projects/openpam/include/security/openpam.h#13 $
*/ */
#ifndef _SECURITY_OPENPAM_H_INCLUDED #ifndef _SECURITY_OPENPAM_H_INCLUDED
@ -65,6 +65,7 @@ pam_error(pam_handle_t *_pamh,
int int
pam_get_authtok(pam_handle_t *_pamh, pam_get_authtok(pam_handle_t *_pamh,
int _item,
const char **_authtok, const char **_authtok,
const char *_prompt); const char *_prompt);

View file

@ -31,7 +31,7 @@
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE. * SUCH DAMAGE.
* *
* $P4: //depot/projects/openpam/include/security/pam_constants.h#12 $ * $P4: //depot/projects/openpam/include/security/pam_constants.h#13 $
*/ */
#ifndef _PAM_CONSTANTS_H_INCLUDED #ifndef _PAM_CONSTANTS_H_INCLUDED
@ -119,6 +119,7 @@ enum {
PAM_RUSER = 8, PAM_RUSER = 8,
PAM_USER_PROMPT = 9, PAM_USER_PROMPT = 9,
PAM_AUTHTOK_PROMPT = 10, /* OpenPAM extension */ PAM_AUTHTOK_PROMPT = 10, /* OpenPAM extension */
PAM_OLDAUTHTOK_PROMPT = 11, /* OpenPAM extension */
PAM_NUM_ITEMS /* OpenPAM extension */ PAM_NUM_ITEMS /* OpenPAM extension */
}; };

View file

@ -31,7 +31,7 @@
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE. * SUCH DAMAGE.
* *
* $P4: //depot/projects/openpam/lib/pam_get_authtok.c#12 $ * $P4: //depot/projects/openpam/lib/pam_get_authtok.c#13 $
*/ */
#include <sys/param.h> #include <sys/param.h>
@ -41,6 +41,9 @@
#include "openpam_impl.h" #include "openpam_impl.h"
const char authtok_prompt[] = "Password:";
const char oldauthtok_prompt[] = "Old Password:";
/* /*
* OpenPAM extension * OpenPAM extension
* *
@ -49,34 +52,51 @@
int int
pam_get_authtok(pam_handle_t *pamh, pam_get_authtok(pam_handle_t *pamh,
int item,
const char **authtok, const char **authtok,
const char *prompt) const char *prompt)
{ {
char *p, *resp; const char *default_prompt;
int r, style; char *resp;
int pitem, r, style;
if (pamh == NULL || authtok == NULL) if (pamh == NULL || authtok == NULL)
return (PAM_SYSTEM_ERR); return (PAM_SYSTEM_ERR);
*authtok = NULL;
switch (item) {
case PAM_AUTHTOK:
pitem = PAM_AUTHTOK_PROMPT;
default_prompt = authtok_prompt;
break;
case PAM_OLDAUTHTOK:
pitem = PAM_OLDAUTHTOK_PROMPT;
default_prompt = oldauthtok_prompt;
break;
default:
return (PAM_SYMBOL_ERR);
}
if (openpam_get_option(pamh, "try_first_pass") || if (openpam_get_option(pamh, "try_first_pass") ||
openpam_get_option(pamh, "use_first_pass")) { openpam_get_option(pamh, "use_first_pass")) {
r = pam_get_item(pamh, PAM_AUTHTOK, (const void **)authtok); r = pam_get_item(pamh, item, (const void **)authtok);
if (r == PAM_SUCCESS && *authtok != NULL) if (r == PAM_SUCCESS && *authtok != NULL)
return (PAM_SUCCESS); return (PAM_SUCCESS);
else if (openpam_get_option(pamh, "use_first_pass")) else if (openpam_get_option(pamh, "use_first_pass"))
return (r == PAM_SUCCESS ? PAM_AUTH_ERR : r); return (r == PAM_SUCCESS ? PAM_AUTH_ERR : r);
} }
if (pam_get_item(pamh, PAM_AUTHTOK_PROMPT, if (prompt == NULL) {
(const void **)&p) != PAM_SUCCESS || p == NULL) r = pam_get_item(pamh, pitem, (const void **)&prompt);
if (prompt == NULL) if (r != PAM_SUCCESS || prompt == NULL)
prompt = "Password:"; prompt = default_prompt;
}
style = openpam_get_option(pamh, "echo_pass") ? style = openpam_get_option(pamh, "echo_pass") ?
PAM_PROMPT_ECHO_ON : PAM_PROMPT_ECHO_OFF; PAM_PROMPT_ECHO_ON : PAM_PROMPT_ECHO_OFF;
r = pam_prompt(pamh, style, &resp, "%s", p ? p : prompt); r = pam_prompt(pamh, style, &resp, "%s", prompt);
if (r != PAM_SUCCESS) if (r != PAM_SUCCESS)
return (r); return (r);
*authtok = resp; *authtok = resp;
return (pam_set_item(pamh, PAM_AUTHTOK, *authtok)); return (pam_set_item(pamh, item, *authtok));
} }
/* /*
@ -87,3 +107,26 @@ pam_get_authtok(pam_handle_t *pamh,
* =pam_set_item * =pam_set_item
* !PAM_SYMBOL_ERR * !PAM_SYMBOL_ERR
*/ */
/**
* The =pam_get_authtok function returns the cached authentication token,
* or prompts the user if no token is currently cached. Either way, a
* pointer to the authentication token is stored in the location pointed
* to by the =authtok argument.
*
* The =item argument must have one of the following values:
*
* =PAM_AUTHTOK
* Returns the current authentication token, or the new token
* when changing authentication tokens.
* =PAM_OLDAUTHTOK
* Returns the previous authentication token when changing
* authentication tokens.
*
* The =prompt argument specifies a prompt to use if no token is cached.
* If =NULL, the =PAM_AUTHTOK_PROMPT or =PAM_OLDAUTHTOK_PROMPT item, as
* appropriate, will be used. If that item is also =NULL, a hardcoded
* default prompt will be used.
*
* >pam_get_item
*/

View file

@ -31,7 +31,7 @@
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE. * SUCH DAMAGE.
* *
* $P4: //depot/projects/openpam/lib/pam_get_item.c#10 $ * $P4: //depot/projects/openpam/lib/pam_get_item.c#11 $
*/ */
#include <sys/param.h> #include <sys/param.h>
@ -66,6 +66,7 @@ pam_get_item(pam_handle_t *pamh,
case PAM_CONV: case PAM_CONV:
case PAM_USER_PROMPT: case PAM_USER_PROMPT:
case PAM_AUTHTOK_PROMPT: case PAM_AUTHTOK_PROMPT:
case PAM_OLDAUTHTOK_PROMPT:
*item = pamh->item[item_type]; *item = pamh->item[item_type];
return (PAM_SUCCESS); return (PAM_SUCCESS);
default: default:
@ -112,6 +113,9 @@ pam_get_item(pam_handle_t *pamh,
* =PAM_AUTHTOK_PROMPT: * =PAM_AUTHTOK_PROMPT:
* The prompt to use when asking the applicant for an * The prompt to use when asking the applicant for an
* authentication token. * authentication token.
* =PAM_OLDAUTHTOK_PROMPT:
* The prompt to use when asking the applicant for an
* expired authentication token prior to changing it.
* *
* See =pam_start for a description of =struct pam_conv. * See =pam_start for a description of =struct pam_conv.
* *

View file

@ -31,7 +31,7 @@
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE. * SUCH DAMAGE.
* *
* $P4: //depot/projects/openpam/lib/pam_set_item.c#12 $ * $P4: //depot/projects/openpam/lib/pam_set_item.c#13 $
*/ */
#include <sys/param.h> #include <sys/param.h>
@ -73,6 +73,7 @@ pam_set_item(pam_handle_t *pamh,
case PAM_RUSER: case PAM_RUSER:
case PAM_USER_PROMPT: case PAM_USER_PROMPT:
case PAM_AUTHTOK_PROMPT: case PAM_AUTHTOK_PROMPT:
case PAM_OLDAUTHTOK_PROMPT:
if (*slot != NULL) if (*slot != NULL)
size = strlen(*slot) + 1; size = strlen(*slot) + 1;
if (item != NULL) if (item != NULL)