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

网络编程

开发平台:

Unix_Linux

  1. /*
  2.  * Program: OSF/1 (Digital UNIX) 4 check password
  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: 13 September 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. /* Dummy collection routine
  36.  * Accepts: how long to wait for user
  37.  *     how to run parameter collection
  38.  *     title
  39.  *     number of prompts
  40.  *     prompts
  41.  * Returns: collection status
  42.  *
  43.  * Because Spider Boardman, who wrote SIA, says that it's needed for buggy SIA
  44.  * mechanisms, that's why.
  45.  */
  46. static int checkpw_collect (int timeout,int rendition,uchar_t *title,
  47.     int nprompts,prompt_t *prompts)
  48. {
  49.   switch (rendition) {
  50.   case SIAONELINER: case SIAINFO: case SIAWARNING: return SIACOLSUCCESS;
  51.   }
  52.   return SIACOLABORT; /* another else is bogus */
  53. }
  54. /* Check password
  55.  * Accepts: login passwd struct
  56.  *     password string
  57.  *     argument count
  58.  *     argument vector
  59.  * Returns: passwd struct if password validated, NIL otherwise
  60.  */
  61. struct passwd *checkpw (struct passwd *pw,char *pass,int argc,char *argv[])
  62. {
  63.   int i;
  64.   char *s;
  65.   char *name = cpystr (pw->pw_name);
  66.   char *host = cpystr (tcp_clienthost ());
  67.   struct passwd *ret = NIL;
  68. /* tie off address */
  69.   if (s = strchr (host,' ')) *s = '';
  70.   if (*host == '[') { /* convert [a.b.c.d] to a.b.c.d */
  71.     memmove (host,host+1,i = strlen (host + 2));
  72.     host[i] = '';
  73.   }
  74. /* validate password */
  75.   if (sia_validate_user (checkpw_collect,argc,argv,host,name,NIL,NIL,NIL,pass)
  76.       == SIASUCCESS) ret = getpwnam (name);
  77.   fs_give ((void **) &name);
  78.   fs_give ((void **) &host);
  79.   return ret;
  80. }