From ca5c3dbfd843b6acd92425a6f56c4b01d1a80dde Mon Sep 17 00:00:00 2001
From: Michal Sekletar <msekleta@redhat.com>
Date: Mon, 21 Sep 2015 14:55:39 +0200
Subject: [PATCH] login: fix label on /run/nologin
rhel-only for now, not yet posted upstream
Resolves: #1264073
---
Makefile.am | 3 ++-
src/login/user-sessions.c | 7 ++++++-
2 files changed, 8 insertions(+), 2 deletions(-)
diff --git a/Makefile.am b/Makefile.am
index 58bcc2c429..0fcb737509 100644
--- a/Makefile.am
+++ b/Makefile.am
@@ -5829,7 +5829,8 @@ systemd_user_sessions_SOURCES = \
src/login/user-sessions.c
systemd_user_sessions_LDADD = \
- libsystemd-shared.la
+ libsystemd-shared.la \
+ libsystemd-label.la
rootlibexec_PROGRAMS += \
systemd-logind \
diff --git a/src/login/user-sessions.c b/src/login/user-sessions.c
index 6edb823e8c..d1d429c0d2 100644
--- a/src/login/user-sessions.c
+++ b/src/login/user-sessions.c
@@ -26,6 +26,7 @@
#include "log.h"
#include "util.h"
#include "fileio.h"
+#include "selinux-util.h"
int main(int argc, char*argv[]) {
@@ -40,6 +41,8 @@ int main(int argc, char*argv[]) {
umask(0022);
+ mac_selinux_init(NULL);
+
if (streq(argv[1], "start")) {
int r = 0;
@@ -66,7 +69,7 @@ int main(int argc, char*argv[]) {
} else if (streq(argv[1], "stop")) {
int r;
- r = write_string_file_atomic("/run/nologin", "System is going down.");
+ r = write_string_file_atomic_label("/run/nologin", "System is going down.");
if (r < 0) {
log_error_errno(r, "Failed to create /run/nologin: %m");
return EXIT_FAILURE;
@@ -77,5 +80,7 @@ int main(int argc, char*argv[]) {
return EXIT_FAILURE;
}
+ mac_selinux_finish();
+
return EXIT_SUCCESS;
}