From: Tobias Stoeckmann Date: Thu, 14 Dec 2023 10:54:00 +0000 (+0100) Subject: src/passwd.c: Switch to day precision X-Git-Tag: 4.15.0-rc1~61 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=3b5ba41d3e9dfc3bf058f0f31529c08201265241;p=thirdparty%2Fshadow.git src/passwd.c: Switch to day precision The size of time_t varies across systems, but since data type long is more than enough to calculate with days (precision of shadow file), use it instead. Just in case a shadow file contains huge values, check for a possible signed integer overflow. Signed-off-by: Tobias Stoeckmann Link: Signed-off-by: Alejandro Colomar --- diff --git a/src/passwd.c b/src/passwd.c index ef7bee85f..a24e62dfd 100644 --- a/src/passwd.c +++ b/src/passwd.c @@ -343,7 +343,6 @@ static int new_password (const struct passwd *pw) */ static void check_password (const struct passwd *pw, const struct spwd *sp) { - time_t now; int exp_status; exp_status = isexpired (pw, sp); @@ -363,8 +362,6 @@ static void check_password (const struct passwd *pw, const struct spwd *sp) return; } - (void) time (&now); - /* * Expired accounts cannot be changed ever. Passwords which are * locked may not be changed. Passwords where min > max may not be @@ -387,10 +384,11 @@ static void check_password (const struct passwd *pw, const struct spwd *sp) * Passwords may only be changed after sp_min time is up. */ if (sp->sp_lstchg > 0) { - time_t ok; - ok = (time_t) sp->sp_lstchg * DAY; + long now, ok; + now = time(NULL) / DAY; + ok = sp->sp_lstchg; if (sp->sp_min > 0) { - ok += (time_t) sp->sp_min * DAY; + ok += sp->sp_min; } if (now < ok) {