Mercurial > hg > Members > kono > nitros9-code
view 3rdparty/packages/uucpbb/src/validuser.c @ 2855:e126b9acab32 lwtools-port
rules.mak: Do not hardcode path for "echo"
It is basically the only tool with full path here and I don't see any
reason for it. We don't use special echo options that would fail
on the shell built-in echo.
Also don't hardcode path for losetup. sudo should make sure you
have the relevant location in your path, and that the path is sanitized,
otherwise your sudo setup is broken.
author | Tormod Volden <debian.tormod@gmail.com> |
---|---|
date | Sat, 13 Jul 2013 11:30:31 +0200 |
parents | 5ba8e711a1a3 |
children |
line wrap: on
line source
/* validuser.c Confirms if the user is in the password file. Copyright (C) 1990, 1993 Rick Adams and Bob Billson This file is part of the OS-9 UUCP package, UUCPbb. This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. The author of UUCPbb, Bob Billson, can be contacted at: bob@kc2wz.bubble.org or uunet!kc2wz!bob or by snail mail: 21 Bates Way, Westfield, NJ 07090 */ /* If the user is in the password file, return TRUE, otherwise FALSE. donated by FILIP (thanks!). */ #include "uucp.h" #include <password.h> EXTERN QQ unsigned myuid; EXTERN QQ char *errorsto; QQ unsigned validuid; /* UID of validated username */ int validuser (user) char *user; { if (chkuser (user) == TRUE) return (TRUE); /* can't find the user, so use the 'errorsto' user instead */ strcpy (user, errorsto); chkuser (user); return (FALSE); } int chkuser (user) char *user; { register PWENT *pwentry; flag result = FALSE; /* assume failure */ asetuid (0); pwentry = getpwnam (user); endpwent(); asetuid (myuid); if (pwentry == (PWENT *)ERROR) fatal ("validuser: can't open password file"); if (pwentry != NULL) { #ifdef _OSK validuid = (unsigned) uIDtoInt(pwentry->uid); #else validuid = (unsigned) atoi (pwentry->uid); #endif result = TRUE; } return ((int)result); }