summaryrefslogtreecommitdiffstats
path: root/usr.sbin
diff options
context:
space:
mode:
Diffstat (limited to 'usr.sbin')
-rw-r--r--usr.sbin/ac/ac.c91
1 files changed, 82 insertions, 9 deletions
diff --git a/usr.sbin/ac/ac.c b/usr.sbin/ac/ac.c
index 89e8884..c562e4f 100644
--- a/usr.sbin/ac/ac.c
+++ b/usr.sbin/ac/ac.c
@@ -83,6 +83,9 @@ static int Debug = 0;
int main(int, char **);
int ac(FILE *);
struct tty_list *add_tty(char *);
+#ifdef DEBUG
+const char *debug_pfx(const struct utmp *, const struct utmp *);
+#endif
int do_tty(char *);
FILE *file(const char *);
struct utmp_list *log_in(struct utmp_list *, struct utmp *);
@@ -208,6 +211,72 @@ update_user(struct user_list *head, char *name, time_t secs)
return up;
}
+#ifdef DEBUG
+/*
+ * Create a string which is the standard prefix for a debug line. It
+ * includes a timestamp (perhaps with year), device-name, and user-name.
+ */
+const char *
+debug_pfx(const struct utmp *event_up, const struct utmp *userinf_up)
+{
+ static char str_result[40+UT_LINESIZE+UT_NAMESIZE];
+ static char thisyear[5];
+ size_t maxcopy;
+ time_t ut_timecopy;
+
+ if (thisyear[0] == '\0') {
+ /* Figure out what "this year" is. */
+ time(&ut_timecopy);
+ strlcpy(str_result, ctime(&ut_timecopy), sizeof(str_result));
+ strlcpy(thisyear, &str_result[20], sizeof(thisyear));
+ }
+
+ if (event_up->ut_time == 0)
+ strlcpy(str_result, "*ZeroTime* --:--:-- ", sizeof(str_result));
+ else {
+ /*
+ * The type of utmp.ut_time is not necessary type time_t, as
+ * it is explicitly defined as type int32_t. Copy the value
+ * for platforms where sizeof(time_t) != sizeof(int32_t).
+ */
+ ut_timecopy = _time32_to_time(event_up->ut_time);
+ strlcpy(str_result, ctime(&ut_timecopy), sizeof(str_result));
+ /*
+ * Include the year, if it is not the same year as "now".
+ */
+ if (strncmp(&str_result[20], thisyear, 4) == 0)
+ str_result[20] = '\0';
+ else {
+ str_result[24] = ' '; /* Replace a '\n' */
+ str_result[25] = '\0';
+ }
+ }
+
+ if (userinf_up->ut_line[0] == '\0')
+ strlcat(str_result, "NoDev", sizeof(str_result));
+ else {
+ /* ut_line is not necessarily null-terminated. */
+ maxcopy = strlen(str_result) + UT_LINESIZE + 1;
+ if (maxcopy > sizeof(str_result))
+ maxcopy = sizeof(str_result);
+ strlcat(str_result, userinf_up->ut_line, maxcopy);
+ }
+ strlcat(str_result, ": ", sizeof(str_result));
+
+ if (userinf_up->ut_name[0] == '\0')
+ strlcat(str_result, "LogOff", sizeof(str_result));
+ else {
+ /* ut_name is not necessarily null-terminated. */
+ maxcopy = strlen(str_result) + UT_NAMESIZE + 1;
+ if (maxcopy > sizeof(str_result))
+ maxcopy = sizeof(str_result);
+ strlcat(str_result, userinf_up->ut_name, maxcopy);
+ }
+
+ return (str_result);
+}
+#endif
+
int
main(int argc, char *argv[])
{
@@ -346,11 +415,10 @@ log_out(struct utmp_list *head, struct utmp *up)
Users = update_user(Users, lp->usr.ut_name, secs);
#ifdef DEBUG
if (Debug)
- printf("%-.*s %-.*s: %-.*s logged out (%2d:%02d:%02d)\n",
- 19, ctime(&up->ut_time),
- sizeof (lp->usr.ut_line), lp->usr.ut_line,
- sizeof (lp->usr.ut_name), lp->usr.ut_name,
- secs / 3600, (secs % 3600) / 60, secs % 60);
+ printf("%s logged out (%2d:%02d:%02d)\n",
+ debug_pfx(up, &lp->usr), (int)(secs / 3600),
+ (int)((secs % 3600) / 60),
+ (int)(secs % 60));
#endif
/*
* now lose it
@@ -426,11 +494,10 @@ log_in(struct utmp_list *head, struct utmp *up)
memmove((char *)&lp->usr, (char *)up, sizeof (struct utmp));
#ifdef DEBUG
if (Debug) {
- printf("%-.*s %-.*s: %-.*s logged in", 19,
- ctime(&lp->usr.ut_time), sizeof (up->ut_line),
- up->ut_line, sizeof (up->ut_name), up->ut_name);
+ printf("%s logged in", debug_pfx(&lp->usr, up));
if (*up->ut_host)
- printf(" (%-.*s)", sizeof (up->ut_host), up->ut_host);
+ printf(" (%-.*s)", (int)sizeof(up->ut_host),
+ up->ut_host);
putchar('\n');
}
#endif
@@ -491,6 +558,12 @@ ac(FILE *fp)
strchr("pqrsPQRS", usr.ut_line[3]) != 0 ||
*usr.ut_host != '\0')
head = log_in(head, &usr);
+#ifdef DEBUG
+ else if (Debug > 1)
+ /* Things such as 'screen' sessions. */
+ printf("%s - record ignored\n",
+ debug_pfx(&usr, &usr));
+#endif
} else
head = log_out(head, &usr);
break;
OpenPOWER on IntegriCloud