From 62dd94b375446eb04aed1550c17eaf79717423d4 Mon Sep 17 00:00:00 2001 From: Damien Miller Date: Sat, 23 Sep 2000 14:26:32 +1100 Subject: [PATCH] - (djm) Tweak password expiry checking at suggestion of Kevin Steves --- ChangeLog | 2 ++ auth.c | 8 ++++---- 2 files changed, 6 insertions(+), 4 deletions(-) diff --git a/ChangeLog b/ChangeLog index 9adb880d2..f0640e55e 100644 --- a/ChangeLog +++ b/ChangeLog @@ -3,6 +3,8 @@ - (djm) Redhat spec and manpage fixes from Pekka Savola - (djm) Seperate tests for int64_t and u_int64_t types + - (djm) Tweak password expiry checking at suggestion of Kevin Steves + 20000920 - (djm) Fix bad path substitution. Report from Andrew Miner diff --git a/auth.c b/auth.c index ae8c79843..883f08ab0 100644 --- a/auth.c +++ b/auth.c @@ -81,8 +81,8 @@ allowed_user(struct passwd * pw) #ifdef WITH_AIXAUTHENTICATE char *loginmsg; #endif /* WITH_AIXAUTHENTICATE */ -#if defined(HAVE_SHADOW_H) && !defined(DISABLE_SHADOW) && \ - defined(HAS_SHADOW_EXPIRE) +#if !defined(PAM) && defined(HAVE_SHADOW_H) && \ + !defined(DISABLE_SHADOW) && defined(HAS_SHADOW_EXPIRE) struct spwd *spw; /* Shouldn't be called if pw is NULL, but better safe than sorry... */ @@ -94,11 +94,11 @@ allowed_user(struct passwd * pw) int days = time(NULL) / 86400; /* Check account expiry */ - if ((spw->sp_expire > 0) && (days > spw->sp_expire)) + if ((spw->sp_expire >= 0) && (days > spw->sp_expire)) return 0; /* Check password expiry */ - if ((spw->sp_lstchg > 0) && (spw->sp_max > 0) && + if ((spw->sp_lstchg >= 0) && (spw->sp_max >= 0) && (days > (spw->sp_lstchg + spw->sp_max))) return 0; }