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

网络编程

开发平台:

Unix_Linux

  1. /*
  2.  * Program: Pluggable Authentication Modules login services, buggy systems
  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: 29 April 1999
  14.  *
  15.  * Copyright 1999 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. static char *pam_uname; /* user name */
  37. static char *pam_pass; /* password */
  38. /* PAM conversation function
  39.  * Accepts: number of messages
  40.  *     vector of messages
  41.  *     pointer to response return
  42.  *     application data
  43.  * Returns: PAM_SUCCESS if OK, response vector filled in, else PAM_CONV_ERR
  44.  */
  45. static int checkpw_conv (int num_msg,const struct pam_message **msg,
  46.  struct pam_response **resp,void *appdata_ptr)
  47. {
  48.   int i;
  49.   struct pam_response *reply = fs_get (sizeof (struct pam_response) * num_msg);
  50.   for (i = 0; i < num_msg; i++) switch (msg[i]->msg_style) {
  51.   case PAM_PROMPT_ECHO_ON: /* assume want user name */
  52.     reply[i].resp_retcode = PAM_SUCCESS;
  53.     reply[i].resp = cpystr (pam_uname);
  54.     break;
  55.   case PAM_PROMPT_ECHO_OFF: /* assume want password */
  56.     reply[i].resp_retcode = PAM_SUCCESS;
  57.     reply[i].resp = cpystr (pam_pass);
  58.     break;
  59.   case PAM_TEXT_INFO:
  60.   case PAM_ERROR_MSG:
  61.     reply[i].resp_retcode = PAM_SUCCESS;
  62.     reply[i].resp = NULL;
  63.     break;
  64.   default: /* unknown message style */
  65.     fs_give ((void **) &reply);
  66.     return PAM_CONV_ERR;
  67.   }
  68.   *resp = reply;
  69.   return PAM_SUCCESS;
  70. }
  71. /* Server log in
  72.  * Accepts: user name string
  73.  *     password string
  74.  * Returns: T if password validated, NIL otherwise
  75.  */
  76. struct passwd *checkpw (struct passwd *pw,char *pass,int argc,char *argv[])
  77. {
  78.   pam_handle_t *hdl;
  79.   struct pam_conv conv;
  80.   conv.conv = &checkpw_conv;
  81.   pam_uname = pw->pw_name;
  82.   pam_pass = pass;
  83.   if ((pam_start ((char *) mail_parameters (NIL,GET_SERVICENAME,NIL),
  84.   pw->pw_name,&conv,&hdl) != PAM_SUCCESS) ||
  85.       (pam_authenticate (hdl,NIL) != PAM_SUCCESS) ||
  86.       (pam_acct_mgmt (hdl,NIL) != PAM_SUCCESS) ||
  87.       (pam_setcred (hdl,PAM_ESTABLISH_CRED) != PAM_SUCCESS)) {
  88.     pam_end (hdl,PAM_AUTH_ERR); /* failed */
  89.     return NIL;
  90.   }
  91.   pam_end (hdl,PAM_SUCCESS); /* return success */
  92.   return pw;
  93. }