diff options
author | Kaarle Ritvanen <kaarle.ritvanen@datakunkku.fi> | 2016-01-02 00:20:39 +0200 |
---|---|---|
committer | Denys Vlasenko <vda.linux@googlemail.com> | 2017-04-13 12:39:03 +0200 |
commit | 517a82c5b6b5e279f3e96a6774445a2952ca312b (patch) | |
tree | 5eff7ec6bb69bceedcea35fce37cf0e4380fea82 /libbb/securetty.c | |
parent | c054822027a4a6895bc95979c6c10ff5763c7c7e (diff) |
login: move check_securetty to libbb
Signed-off-by: Kaarle Ritvanen <kaarle.ritvanen@datakunkku.fi>
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
Diffstat (limited to 'libbb/securetty.c')
-rw-r--r-- | libbb/securetty.c | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/libbb/securetty.c b/libbb/securetty.c new file mode 100644 index 000000000..176cee129 --- /dev/null +++ b/libbb/securetty.c @@ -0,0 +1,22 @@ +/* vi: set sw=4 ts=4: */ +/* + * /etc/securetty checking. + * + * Licensed under GPLv2, see file LICENSE in this source tree. + */ +#include "libbb.h" + +int FAST_FUNC check_securetty(const char *short_tty) +{ + char *buf = (char*)"/etc/securetty"; /* any non-NULL is ok */ + parser_t *parser = config_open2("/etc/securetty", fopen_for_read); + while (config_read(parser, &buf, 1, 1, "# \t", PARSE_NORMAL)) { + if (strcmp(buf, short_tty) == 0) + break; + buf = NULL; + } + config_close(parser); + /* buf != NULL here if config file was not found, empty + * or line was found which equals short_tty */ + return buf != NULL; +} |