ckp_pam.c
上传用户:ycwykj01
上传日期:2007-01-04
资源大小:1819k
文件大小:3k
源码类别:

网络编程

开发平台:

Unix_Linux

  1. /*
  2.  * Program: Pluggable Authentication Modules login services
  3.  *
  4.  * Author: Mark Crispin
  5.  * Networks and Distributed Computing
  6.  * Computing & Communications
  7.  * University of Washington
  8.  * Administration Building, AG-44
  9.  * Seattle, WA  98195
  10.  * Internet: MRC@CAC.Washington.EDU
  11.  *
  12.  * Date: 1 August 1988
  13.  * Last Edited: 14 December 1998
  14.  *
  15.  * Copyright 1998 by the University of Washington
  16.  *
  17.  *  Permission to use, copy, modify, and distribute this software and its
  18.  * documentation for any purpose and without fee is hereby granted, provided
  19.  * that the above copyright notice appears in all copies and that both the
  20.  * above copyright notice and this permission notice appear in supporting
  21.  * documentation, and that the name of the University of Washington not be
  22.  * used in advertising or publicity pertaining to distribution of the software
  23.  * without specific, written prior permission.  This software is made available
  24.  * "as is", and
  25.  * THE UNIVERSITY OF WASHINGTON DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED,
  26.  * WITH REGARD TO THIS SOFTWARE, INCLUDING WITHOUT LIMITATION ALL IMPLIED
  27.  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, AND IN
  28.  * NO EVENT SHALL THE UNIVERSITY OF WASHINGTON BE LIABLE FOR ANY SPECIAL,
  29.  * INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
  30.  * LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, TORT
  31.  * (INCLUDING NEGLIGENCE) OR STRICT LIABILITY, ARISING OUT OF OR IN CONNECTION
  32.  * WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
  33.  *
  34.  */
  35. #include <security/pam_appl.h>
  36. struct checkpw_cred {
  37.   char *uname; /* user name */
  38.   char *pass; /* password */
  39. };
  40. /* PAM conversation function
  41.  * Accepts: number of messages
  42.  *     vector of messages
  43.  *     pointer to response return
  44.  *     application data
  45.  * Returns: PAM_SUCCESS if OK, response vector filled in, else PAM_CONV_ERR
  46.  */
  47. static int checkpw_conv (int num_msg,const struct pam_message **msg,
  48.  struct pam_response **resp,void *appdata_ptr)
  49. {
  50.   int i;
  51.   struct checkpw_cred *cred = (struct checkpw_cred *) appdata_ptr;
  52.   struct pam_response *reply = fs_get (sizeof (struct pam_response) * num_msg);
  53.   for (i = 0; i < num_msg; i++) switch (msg[i]->msg_style) {
  54.   case PAM_PROMPT_ECHO_ON: /* assume want user name */
  55.     reply[i].resp_retcode = PAM_SUCCESS;
  56.     reply[i].resp = cpystr (cred->uname);
  57.     break;
  58.   case PAM_PROMPT_ECHO_OFF: /* assume want password */
  59.     reply[i].resp_retcode = PAM_SUCCESS;
  60.     reply[i].resp = cpystr (cred->pass);
  61.     break;
  62.   case PAM_TEXT_INFO:
  63.   case PAM_ERROR_MSG:
  64.     reply[i].resp_retcode = PAM_SUCCESS;
  65.     reply[i].resp = NULL;
  66.     break;
  67.   default: /* unknown message style */
  68.     fs_give ((void **) &reply);
  69.     return PAM_CONV_ERR;
  70.   }
  71.   *resp = reply;
  72.   return PAM_SUCCESS;
  73. }
  74. /* Server log in
  75.  * Accepts: user name string
  76.  *     password string
  77.  * Returns: T if password validated, NIL otherwise
  78.  */
  79. struct passwd *checkpw (struct passwd *pw,char *pass,int argc,char *argv[])
  80. {
  81.   pam_handle_t *hdl;
  82.   struct pam_conv conv;
  83.   struct checkpw_cred cred;
  84.   conv.conv = &checkpw_conv;
  85.   conv.appdata_ptr = &cred;
  86.   cred.uname = pw->pw_name;
  87.   cred.pass = pass;
  88.   if ((pam_start ((char *) mail_parameters (NIL,GET_SERVICENAME,NIL),
  89.   pw->pw_name,&conv,&hdl) != PAM_SUCCESS) ||
  90.       (pam_authenticate (hdl,NIL) != PAM_SUCCESS) ||
  91.       (pam_acct_mgmt (hdl,NIL) != PAM_SUCCESS) ||
  92.       (pam_setcred (hdl,PAM_ESTABLISH_CRED) != PAM_SUCCESS)) {
  93.     pam_end (hdl,PAM_AUTH_ERR); /* failed */
  94.     return NIL;
  95.   }
  96.   pam_end (hdl,PAM_SUCCESS); /* return success */
  97.   return pw;
  98. }