|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
From de1a1440dd81857ae679672ae1d757bfbdd2e112 Mon Sep 17 00:00:00 2001
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
From: Colin Guthrie <colin@mageia.org>
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
Date: Sun, 2 Nov 2014 13:33:16 +0000
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
Subject: [PATCH] manager: Ensure user's systemd runtime directory exists.
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
This mirrors code in dbus.c when creating the private socket and
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
avoids error messages like:
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
systemd[1353]: bind(/run/user/603/systemd/notify) failed: No such file or directory
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
systemd[1353]: Failed to fully start up daemon: No such file or directory
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
(cherry picked from commit 0c3f25e0c1f028d4da9cc5253abf0322230e6835)
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
---
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
src/core/manager.c | 12 ++++++++----
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
1 file changed, 8 insertions(+), 4 deletions(-)
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
diff --git a/src/core/manager.c b/src/core/manager.c
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
index ff29ae1d9d..47e23ba80e 100644
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
--- a/src/core/manager.c
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
+++ b/src/core/manager.c
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
@@ -662,9 +662,11 @@ static int manager_setup_notify(Manager *m) {
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
return -errno;
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
}
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
- if (m->running_as == SYSTEMD_SYSTEM)
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
+ if (m->running_as == SYSTEMD_SYSTEM) {
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
m->notify_socket = strdup("/run/systemd/notify");
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
- else {
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
+ if (!m->notify_socket)
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
+ return log_oom();
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
+ } else {
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
const char *e;
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
e = getenv("XDG_RUNTIME_DIR");
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
@@ -674,9 +676,11 @@ static int manager_setup_notify(Manager *m) {
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
}
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
m->notify_socket = strappend(e, "/systemd/notify");
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
+ if (!m->notify_socket)
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
+ return log_oom();
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
+
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
+ mkdir_parents_label(m->notify_socket, 0755);
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
}
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
- if (!m->notify_socket)
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
- return log_oom();
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
strncpy(sa.un.sun_path, m->notify_socket, sizeof(sa.un.sun_path)-1);
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
r = bind(fd, &sa.sa, offsetof(struct sockaddr_un, sun_path) + strlen(sa.un.sun_path));
|