summaryrefslogtreecommitdiff
path: root/src/user-sessions/user-sessions.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/user-sessions/user-sessions.c')
-rw-r--r--src/user-sessions/user-sessions.c32
1 files changed, 14 insertions, 18 deletions
diff --git a/src/user-sessions/user-sessions.c b/src/user-sessions/user-sessions.c
index 89c4b0005d..490d9f01a9 100644
--- a/src/user-sessions/user-sessions.c
+++ b/src/user-sessions/user-sessions.c
@@ -6,22 +6,20 @@
#include "fileio.h"
#include "fileio-label.h"
#include "fs-util.h"
+#include "main-func.h"
#include "log.h"
#include "selinux-util.h"
#include "string-util.h"
#include "util.h"
-int main(int argc, char*argv[]) {
+static int run(int argc, char *argv[]) {
int r, k;
- if (argc != 2) {
- log_error("This program requires one argument.");
- return EXIT_FAILURE;
- }
+ if (argc != 2)
+ return log_error_errno(SYNTHETIC_ERRNO(EINVAL),
+ "This program requires one argument.");
- log_set_target(LOG_TARGET_AUTO);
- log_parse_environment();
- log_open();
+ log_setup_service();
umask(0022);
@@ -30,16 +28,14 @@ int main(int argc, char*argv[]) {
if (streq(argv[1], "start")) {
r = unlink_or_warn("/run/nologin");
k = unlink_or_warn("/etc/nologin");
- if (k < 0 && r >= 0)
- r = k;
+ if (r < 0)
+ return r;
+ return k;
} else if (streq(argv[1], "stop"))
- r = create_shutdown_run_nologin_or_warn();
- else {
- log_error("Unknown verb '%s'.", argv[1]);
- r = -EINVAL;
- }
-
- mac_selinux_finish();
- return r < 0 ? EXIT_FAILURE : EXIT_SUCCESS;
+ return create_shutdown_run_nologin_or_warn();
+
+ return log_error_errno(SYNTHETIC_ERRNO(EINVAL), "Unknown verb '%s'.", argv[1]);
}
+
+DEFINE_MAIN_FUNCTION(run);