diff options
author | Eric Andersen | 2004-07-30 17:24:47 +0000 |
---|---|---|
committer | Eric Andersen | 2004-07-30 17:24:47 +0000 |
commit | aad29b37a7345207c94e8ef9f0bac943d43dbe12 (patch) | |
tree | 5dc7bdc6d5ffd211abc3e76e8b43f2e53fba3e10 /loginutils | |
parent | 15b588559bf75ebe15bc6ff29f3d591c4f35c0e8 (diff) | |
download | busybox-aad29b37a7345207c94e8ef9f0bac943d43dbe12.zip busybox-aad29b37a7345207c94e8ef9f0bac943d43dbe12.tar.gz |
Fixup getty, login, etc so the utmp and wtmp are updated, allowing
the 'who' and 'last' applets among other things to work as expected.
-Erik
Diffstat (limited to 'loginutils')
-rw-r--r-- | loginutils/Config.in | 9 | ||||
-rw-r--r-- | loginutils/getty.c | 10 | ||||
-rw-r--r-- | loginutils/login.c | 7 |
3 files changed, 21 insertions, 5 deletions
diff --git a/loginutils/Config.in b/loginutils/Config.in index db038ab..d9938b0 100644 --- a/loginutils/Config.in +++ b/loginutils/Config.in @@ -57,6 +57,15 @@ config CONFIG_GETTY help getty lets you log in on a tty, it is normally invoked by init. +config CONFIG_FEATURE_U_W_TMP + bool " Support utmp and wtmp files" + depends on CONFIG_GETTY || CONFIG_LOGIN || CONFIG_SU || CONFIG_WHO || CONFIG_LAST + default n + help + The files /var/run/utmp and /var/run/wtmp can be used to track when + user's have logged into and logged out of the system, allowing programs + such as 'who' and 'last' to list who is currently logged in. + config CONFIG_LOGIN bool "login" default n diff --git a/loginutils/getty.c b/loginutils/getty.c index b211733..2b37136 100644 --- a/loginutils/getty.c +++ b/loginutils/getty.c @@ -228,7 +228,7 @@ static void termio_final(struct options *op, struct termio *tp, struct chardata *cp); static int caps_lock(const char *s); -static int bcode(const char *s); +static int bcode(char *s); static void error(const char *fmt, ...) __attribute__ ((noreturn)); #ifdef CONFIG_FEATURE_U_W_TMP @@ -503,6 +503,9 @@ static void update_utmp(char *line) * utmp file can be opened for update, and if we are able to find our * entry in the utmp file. */ + if (access(_PATH_UTMP, R_OK|W_OK) == -1) { + creat(_PATH_UTMP, O_RDWR); + } utmpname(_PATH_UTMP); setutent(); while ((utp = getutent()) @@ -531,6 +534,9 @@ static void update_utmp(char *line) endutent(); { + if (access(_PATH_WTMP, R_OK|W_OK) == -1) { + creat(_PATH_WTMP, O_RDWR); + } updwtmp(_PATH_WTMP, &ut); } } @@ -953,7 +959,7 @@ static int caps_lock(const char *s) } /* bcode - convert speed string to speed code; return 0 on failure */ -static int bcode(const char *s) +static int bcode(char *s) { int r; unsigned long value; diff --git a/loginutils/login.c b/loginutils/login.c index 20fab07..93d81d3 100644 --- a/loginutils/login.c +++ b/loginutils/login.c @@ -403,8 +403,6 @@ static void motd ( ) #ifdef CONFIG_FEATURE_U_W_TMP // vv Taken from tinylogin utmp.c vv -#define _WTMP_FILE "/var/log/wtmp" - #define NO_UTENT \ "No utmp entry. You must exec \"login\" from the lowest level \"sh\"" #define NO_TTY \ @@ -480,6 +478,9 @@ static void setutmp(const char *name, const char *line) setutent(); pututline(&utent); endutent(); - updwtmp(_WTMP_FILE, &utent); + if (access(_PATH_WTMP, R_OK|W_OK) == -1) { + creat(_PATH_WTMP, O_RDWR); + } + updwtmp(_PATH_WTMP, &utent); } #endif /* CONFIG_FEATURE_U_W_TMP */ |