diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-06-26 16:18:39 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-06-26 16:18:39 +0000 |
commit | 5242eef8fc54636a41701fd9d7083ba6e4a4e0b3 (patch) | |
tree | e6a0980092957865a937cc0f34446df3d5194e99 /libmisc/log.c | |
parent | Releasing progress-linux version 1:4.13+dfsg1-5~progress7.99u1. (diff) | |
download | shadow-5242eef8fc54636a41701fd9d7083ba6e4a4e0b3.tar.xz shadow-5242eef8fc54636a41701fd9d7083ba6e4a4e0b3.zip |
Merging upstream version 1:4.15.2.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'libmisc/log.c')
-rw-r--r-- | libmisc/log.c | 93 |
1 files changed, 0 insertions, 93 deletions
diff --git a/libmisc/log.c b/libmisc/log.c deleted file mode 100644 index a220be0..0000000 --- a/libmisc/log.c +++ /dev/null @@ -1,93 +0,0 @@ -/* - * SPDX-FileCopyrightText: 1989 - 1994, Julianne Frances Haugh - * SPDX-FileCopyrightText: 1996 - 1998, Marek Michałkiewicz - * SPDX-FileCopyrightText: 2003 - 2005, Tomasz Kłoczko - * SPDX-FileCopyrightText: 2008 , Nicolas François - * - * SPDX-License-Identifier: BSD-3-Clause - */ - -#include <config.h> - -#ident "$Id$" - -#include <sys/types.h> -#include <pwd.h> -#include <fcntl.h> -#include <time.h> -#include "defines.h" -#include <lastlog.h> -#include "prototypes.h" - -/* - * dolastlog - create lastlog entry - * - * A "last login" entry is created for the user being logged in. The - * UID is extracted from the global (struct passwd) entry and the - * TTY information is gotten from the (struct utmp). - */ -void dolastlog ( - struct lastlog *ll, - const struct passwd *pw, - /*@unique@*/const char *line, - /*@unique@*/const char *host) -{ - int fd; - off_t offset; - struct lastlog newlog; - time_t ll_time; - - /* - * If the file does not exist, don't create it. - */ - - fd = open (LASTLOG_FILE, O_RDWR); - if (-1 == fd) { - return; - } - - /* - * The file is indexed by UID number. Seek to the record - * for this UID. Negative UID's will create problems, but ... - */ - - offset = (off_t) pw->pw_uid * sizeof newlog; - - if (lseek (fd, offset, SEEK_SET) != offset) { - SYSLOG ((LOG_WARN, - "Can't read last lastlog entry for UID %lu in %s. Entry not updated.", - (unsigned long) pw->pw_uid, LASTLOG_FILE)); - (void) close (fd); - return; - } - - /* - * Read the old entry so we can tell the user when they last - * logged in. Then construct the new entry and write it out - * the way we read the old one in. - */ - - if (read (fd, (void *) &newlog, sizeof newlog) != (ssize_t) sizeof newlog) { - memzero (&newlog, sizeof newlog); - } - if (NULL != ll) { - *ll = newlog; - } - - ll_time = newlog.ll_time; - (void) time (&ll_time); - newlog.ll_time = ll_time; - strncpy (newlog.ll_line, line, sizeof (newlog.ll_line) - 1); -#if HAVE_LL_HOST - strncpy (newlog.ll_host, host, sizeof (newlog.ll_host) - 1); -#endif - if ( (lseek (fd, offset, SEEK_SET) != offset) - || (write (fd, (const void *) &newlog, sizeof newlog) != (ssize_t) sizeof newlog) - || (close (fd) != 0)) { - SYSLOG ((LOG_WARN, - "Can't write lastlog entry for UID %lu in %s.", - (unsigned long) pw->pw_uid, LASTLOG_FILE)); - (void) close (fd); - } -} - |