summaryrefslogtreecommitdiffstats
path: root/libmisc/log.c
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-06-26 16:18:39 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-06-26 16:18:39 +0000
commit5242eef8fc54636a41701fd9d7083ba6e4a4e0b3 (patch)
treee6a0980092957865a937cc0f34446df3d5194e99 /libmisc/log.c
parentReleasing progress-linux version 1:4.13+dfsg1-5~progress7.99u1. (diff)
downloadshadow-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.c93
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);
- }
-}
-