]> git.ipfire.org Git - thirdparty/util-linux.git/commitdiff
nologin: add new command
authorKarel Zak <kzak@redhat.com>
Mon, 30 Sep 2013 11:36:26 +0000 (13:36 +0200)
committerKarel Zak <kzak@redhat.com>
Mon, 30 Sep 2013 11:36:26 +0000 (13:36 +0200)
Currently it's maintained as distro specific (or people use impolite
/bin/false way).

Signed-off-by: Karel Zak <kzak@redhat.com>
.gitignore
Documentation/releases/v2.24-ReleaseNotes
configure.ac
include/pathnames.h
login-utils/Makemodule.am
login-utils/nologin.8 [new file with mode: 0644]
login-utils/nologin.c [new file with mode: 0644]

index aedce561d43f907c2df95077f365e7ab7aa50482..91b625f4409b9ec3b2621d364e3db60a9fae235f 100644 (file)
@@ -130,6 +130,7 @@ tests/run.sh.trs
 /mountpoint
 /namei
 /newgrp
+/nologin
 /nsenter
 /partx
 /pg
index 1cd6eec9c1db3ee71d861277486932ec1e2ba08e..ca5b7bc85de07b94d501c486a3189b9c0a95dd56 100644 (file)
@@ -61,6 +61,10 @@ wipefs(8):
   - supports new command line option --backup to backup erased data to
     $HOME/wipefs-<devname>-<offset>.bak
 
+nologin(8):
+  - this command has been merged into util-linux, the command politely
+    refuse a login.
+
 
 Stable maintenance releases between v2.23 and v2.24
 ---------------------------------------------------
index 553228af2659ab7cfb262a5c1318848b60e2aa45..098692c9f9a46b9f9252ae026face3fac094752f 100644 (file)
@@ -1211,6 +1211,14 @@ AS_IF([test "x$enable_login_stat_mail" = xyes], [
 ])
 
 
+AC_ARG_ENABLE([nologin],
+  AS_HELP_STRING([--disable-nologin], [do not build nologin]),
+  [], [enable_nologin=yes]
+)
+UL_BUILD_INIT([nologin])
+AM_CONDITIONAL([BUILD_NOLOGIN], [test "x$build_nologin" = xyes])
+
+
 AC_ARG_ENABLE([sulogin],
   AS_HELP_STRING([--disable-sulogin], [do not build sulogin]),
   [], [enable_sulogin=yes]
index e25234c45a477b172eb5b349b445db7c7f4de49a..dce98d2a42e5ee4cef63c2c4adc9682c0182fad3 100644 (file)
@@ -31,6 +31,8 @@
 #define        _PATH_HUSHLOGIN         ".hushlogin"
 #define        _PATH_HUSHLOGINS        "/etc/hushlogins"
 
+#define _PATH_NOLOGIN_TXT      "/etc/nologin.txt"
+
 #ifndef _PATH_MAILDIR
 #define        _PATH_MAILDIR           "/var/spool/mail"
 #endif
index c5e8c07ae27728c660bf67f659ff3e4f1b52adba..aca028a29138b0b0866da8ca2b7914f81beae10b 100644 (file)
@@ -60,6 +60,13 @@ endif
 endif # BUILD_LOGIN
 
 
+if BUILD_NOLOGIN
+sbin_PROGRAMS += nologin
+dist_man_MANS += login-utils/nologin.8
+nologin_SOURCES = login-utils/nologin.c
+endif
+
+
 if BUILD_UTMPDUMP
 usrbin_exec_PROGRAMS += utmpdump
 dist_man_MANS += login-utils/utmpdump.1
diff --git a/login-utils/nologin.8 b/login-utils/nologin.8
new file mode 100644 (file)
index 0000000..b4e1070
--- /dev/null
@@ -0,0 +1,53 @@
+.\" -*- nroff -*-
+.TH NOLOGIN 8 "September 2013" "util-linux" "System Administration"
+.SH NAME
+nologin \- politely refuse a login
+.SH SYNOPSIS
+.B nologin
+.RB [ \-V ]
+.RB [ \-h ]
+.SH DESCRIPTION
+.B nologin
+displays a message that an account is not available and exits non-zero.  It is
+intended as a replacement shell field to deny login access to account.
+.PP
+If the file /etc/nologin.txt exists, nologin displays its contents to the 
+user instead of the default message.
+.PP
+The exit code returned by
+.B nologin
+is always 1.
+.PP
+.SH OPTIONS
+.IP "\fB\-h, \-\-help\fP"
+Print help and exit.
+.IP "\fB-V, \-\-version"
+Print version and exit.
+.SH NOTES
+.B nologin
+is per-account way to disable login (usually used for system accounts like http or ftp).
+.BR nologin (8)
+uses /etc/nologin.txt as optional source for non-default message, the login
+access is always refused independently on the file.
+.PP
+.BR pam_nologin (8)
+PAM module usually prevents all non-root users from logging into the system.
+.BR pam_nologin (8)
+functionality is controled by /var/run/nologin or /etc/nologin file. 
+.SH AUTHORS
+.UR kzak@redhat.com
+Karel Zak
+.UE
+.SH SEE ALSO
+.BR login (1),
+.BR passwd (5),
+.BR pam_nologin (8)
+.SH HISTORY
+The
+.B nologin
+command appeared in 4.4BSD.
+.SH AVAILABILITY
+The nologin command is part of the util-linux package and is available from
+.UR ftp://\:ftp.kernel.org\:/pub\:/linux\:/utils\:/util-linux/
+Linux Kernel Archive
+.UE .
diff --git a/login-utils/nologin.c b/login-utils/nologin.c
new file mode 100644 (file)
index 0000000..a4fb82d
--- /dev/null
@@ -0,0 +1,75 @@
+/*
+ * Copyright (C) 2013 Karel Zak <kzak@redhat.com>
+ */
+
+#include <stdio.h>
+#include <sys/types.h>
+#include <fcntl.h>
+#include <string.h>
+#include <unistd.h>
+#include <stdlib.h>
+#include <getopt.h>
+
+#include "c.h"
+#include "nls.h"
+#include "pathnames.h"
+
+/*
+ * Always return EXIT_FAILURE (1), don't try to be smart!
+ */
+
+static void __attribute__((__noreturn__)) usage(FILE *out)
+{
+       fputs(USAGE_HEADER, out);
+
+       fprintf(out,
+               _(" %s [options]\n"), program_invocation_short_name);
+
+       fputs(USAGE_OPTIONS, out);
+       fputs(USAGE_HELP, out);
+       fputs(USAGE_VERSION, out);
+
+       fprintf(out, USAGE_MAN_TAIL("nologin(8)"));
+       exit(EXIT_FAILURE);
+}
+
+int main(int argc, char *argv[])
+{
+       int c, fd;
+       static const struct option longopts[] = {
+               { "help",    0, 0, 'h' },
+               { "version", 0, 0, 'V' },
+               { NULL, 0, 0, 0 }
+       };
+
+       setlocale(LC_ALL, "");
+       bindtextdomain(PACKAGE, LOCALEDIR);
+       textdomain(PACKAGE);
+
+       while ((c = getopt_long(argc, argv, "hV", longopts, NULL)) != -1) {
+               switch (c) {
+               case 'h':
+                       usage(stdout);
+                       break;
+               case 'V':
+                       printf(UTIL_LINUX_VERSION);
+                       return EXIT_FAILURE;
+               default:
+                       usage(stderr);
+                       break;
+               }
+       }
+
+       fd = open(_PATH_NOLOGIN_TXT, O_RDONLY);
+       if (fd >= 0) {
+               char buf[BUFSIZ];
+               ssize_t rd;
+
+               while ((rd = read(fd, buf, sizeof(buf))) > 0)
+                       ignore_result( write(STDOUT_FILENO, buf, rd) );
+               close(fd);
+       } else
+               fprintf(stdout, _("This account is currently not available.\n"));
+
+       return EXIT_FAILURE;
+}