/* * Copyright (C) 1998 Christian Esken * Copyright (C) 2003 Oswald Buddenhagen * * This is a modified version of checkpass_shadow.cpp * * Modifications made by Thorsten Kukuk * Mathias Kettner * * ------------------------------------------------------------ * * 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ #include "kcheckpass.h" /******************************************************************* * This is the authentication code for /etc/passwd and Shadow-Passwords *******************************************************************/ #if defined(HAVE_SHADOW) || defined(HAVE_ETCPASSWD) #include #include #include #include #ifndef __hpux #include #endif AuthReturn Authenticate(const char *method, const char *login, char *(*conv) (ConvRequest, const char *)) { char *typed_in_password; char *crpt_passwd; char *password; struct passwd *pw; if (strcmp(method, "classic")) return AuthError; if (!(pw = getpwnam(login))) return AuthAbort; #ifdef HAVE_SHADOW struct spwd *spw = getspnam(login); password = spw ? spw->sp_pwdp : pw->pw_passwd; #else password = pw->pw_passwd; #endif if (!*password) return AuthOk; if (!(typed_in_password = conv(ConvGetHidden, 0))) return AuthAbort; #if defined( __linux__ ) && defined( HAVE_PW_ENCRYPT ) crpt_passwd = pw_encrypt(typed_in_password, password); /* (1) */ #else crpt_passwd = crypt(typed_in_password, password); #endif dispose(typed_in_password); if (crpt_passwd && !strcmp(password, crpt_passwd)) return AuthOk; /* Success */ return AuthBad; /* Password wrong or account locked */ } /* (1) Deprecated - long passwords have known weaknesses. Also, pw_encrypt is non-standard (requires libshadow.a) while everything else you need to support shadow passwords is in the standard (ELF) libc. */ #endif