home *** CD-ROM | disk | FTP | other *** search
/ rtsi.com / 2014.01.www.rtsi.com.tar / www.rtsi.com / OS9 / OSK / TELECOM / UUCPBB21 / uucpbb21.lzh / UUCPBB21 / validuser.c < prev    next >
Text File  |  1994-09-25  |  2KB  |  76 lines

  1. /*  validuser.c    Confirms if the user is in the password file.
  2.     Copyright (C) 1990, 1993  Rick Adams and Bob Billson
  3.  
  4.     This file is part of the OS-9 UUCP package, UUCPbb.
  5.  
  6.     This program is free software; you can redistribute it and/or modify
  7.     it under the terms of the GNU General Public License as published by
  8.     the Free Software Foundation; either version 2 of the License, or
  9.     (at your option) any later version.
  10.  
  11.     This program is distributed in the hope that it will be useful,
  12.     but WITHOUT ANY WARRANTY; without even the implied warranty of
  13.     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  14.     GNU General Public License for more details.
  15.  
  16.     You should have received a copy of the GNU General Public License
  17.     along with this program; if not, write to the Free Software
  18.     Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  19.  
  20.     The author of UUCPbb, Bob Billson, can be contacted at:
  21.     bob@kc2wz.bubble.org  or  uunet!kc2wz!bob  or  by snail mail:
  22.     21 Bates Way, Westfield, NJ 07090
  23. */
  24.  
  25. /* If the user is in the password file, return TRUE, otherwise FALSE.
  26.    donated by FILIP (thanks!). */
  27.  
  28. #include "uucp.h"
  29. #include <password.h>
  30.  
  31. EXTERN QQ unsigned myuid;
  32. EXTERN QQ char *errorsto;
  33. QQ unsigned validuid;                     /* UID of validated username */
  34.  
  35.  
  36. int validuser (user)
  37. char *user;
  38. {
  39.      if (chkuser (user) == TRUE)
  40.           return (TRUE);
  41.  
  42.      /* can't find the user, so use the 'errorsto' user instead */
  43.      strcpy (user, errorsto);
  44.      chkuser (user);
  45.      return (FALSE);
  46. }
  47.  
  48.  
  49.  
  50. int chkuser (user)
  51. char *user;
  52. {
  53.      register PWENT *pwentry;
  54.      flag result = FALSE;                     /* assume failure */
  55.  
  56.      asetuid (0);
  57.      pwentry = getpwnam (user);
  58.      endpwent();
  59.      asetuid (myuid);
  60.  
  61.      if (pwentry == (PWENT *)ERROR)
  62.           fatal ("validuser: can't open password file");
  63.  
  64.      if (pwentry != NULL)
  65.        {
  66. #ifdef _OSK
  67.           validuid = (unsigned) uIDtoInt(pwentry->uid);
  68. #else
  69.           validuid = (unsigned) atoi (pwentry->uid);
  70. #endif
  71.           result = TRUE;
  72.        }
  73.  
  74.      return ((int)result);
  75. }
  76.