From c172c8e3f17a4a35760ec236373c0b06dbcd86bd Mon Sep 17 00:00:00 2001 From: Sheldon Hearn Date: Wed, 12 Apr 2000 08:49:14 +0000 Subject: Use an MD5 checksum to test for file changes; the previous method of using file mtimes could result in chpasss(1) erroneously detecting that no changes were made for non-interactive edits. PR: 4238 Reported by: Jens Schweikhardt Submitted by: Daniel Hagan --- chpass/edit.c | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) (limited to 'chpass/edit.c') diff --git a/chpass/edit.c b/chpass/edit.c index a8c5cc2..6311d57 100644 --- a/chpass/edit.c +++ b/chpass/edit.c @@ -43,6 +43,7 @@ static const char sccsid[] = "@(#)edit.c 8.3 (Berkeley) 4/2/94"; #include #include #include +#include #include #include #include @@ -65,17 +66,23 @@ edit(pw) struct passwd *pw; { struct stat begin, end; + char *begin_sum, *end_sum; for (;;) { if (stat(tempname, &begin)) pw_error(tempname, 1, 1); + begin_sum = MD5File(tempname, (char *)NULL); pw_edit(1); if (stat(tempname, &end)) pw_error(tempname, 1, 1); - if (begin.st_mtime == end.st_mtime) { + end_sum = MD5File(tempname, (char *)NULL); + if ((begin.st_mtime == end.st_mtime) && + (strcmp(begin_sum, end_sum) == 0)) { warnx("no changes made"); pw_error(NULL, 0, 0); } + free(begin_sum); + free(end_sum); if (verify(pw)) break; pw_prompt(); -- cgit v1.2.3-56-ge451