[systemd-commits] 2 commits - TODO src/login
Lennart Poettering
lennart at kemper.freedesktop.org
Wed Jun 19 19:04:29 PDT 2013
TODO | 2 -
src/login/org.freedesktop.login1.conf | 4 ++
src/login/sd-login.c | 48 +---------------------------------
3 files changed, 7 insertions(+), 47 deletions(-)
New commits:
commit ba73ed858f27355d088fe2d96cb8c7e9eb75ff0c
Author: Lennart Poettering <lennart at poettering.net>
Date: Thu Jun 20 04:03:38 2013 +0200
sd-login: update machine enumeration/notifications APIs for new /run/systemd/machines/
diff --git a/TODO b/TODO
index f0af723..0b4048b 100644
--- a/TODO
+++ b/TODO
@@ -44,7 +44,7 @@ Features:
RUNNING/LISTENING states of its socket
* slices:
- - add option to pam_systemd to move login session into a slice
+ - add option to pam_systemd to move login session into a slice (?)
- remove ControlGroup= setting
- in sd_pid_get_owner_uid() fallback to query session file
- add api to determine slice of unit
diff --git a/src/login/sd-login.c b/src/login/sd-login.c
index d2e9503..875d134 100644
--- a/src/login/sd-login.c
+++ b/src/login/sd-login.c
@@ -592,40 +592,7 @@ _public_ int sd_get_uids(uid_t **users) {
}
_public_ int sd_get_machine_names(char ***machines) {
- _cleanup_closedir_ DIR *d = NULL;
- _cleanup_strv_free_ char **l = NULL;
- _cleanup_free_ char *md = NULL;
- char *n;
- int c = 0, r;
-
- r = cg_get_root_path(&md);
- if (r < 0)
- return r;
-
- r = cg_enumerate_subgroups(SYSTEMD_CGROUP_CONTROLLER, md, &d);
- if (r < 0)
- return r;
-
- while ((r = cg_read_subgroup(d, &n)) > 0) {
-
- r = strv_push(&l, n);
- if (r < 0) {
- free(n);
- return -ENOMEM;
- }
-
- c++;
- }
-
- if (r < 0)
- return r;
-
- if (machines) {
- *machines = l;
- l = NULL;
- }
-
- return c;
+ return get_files_in_directory("/run/systemd/machines/", machines);
}
static inline int MONITOR_TO_FD(sd_login_monitor *m) {
@@ -678,18 +645,7 @@ _public_ int sd_login_monitor_new(const char *category, sd_login_monitor **m) {
}
if (!category || streq(category, "machine")) {
- _cleanup_free_ char *md = NULL, *p = NULL;
- int r;
-
- r = cg_get_root_path(&md);
- if (r < 0)
- return r;
-
- r = cg_get_path(SYSTEMD_CGROUP_CONTROLLER, md, NULL, &p);
- if (r < 0)
- return r;
-
- k = inotify_add_watch(fd, p, IN_MOVED_TO|IN_CREATE|IN_DELETE);
+ k = inotify_add_watch(fd, "/run/systemd/machines/", IN_MOVED_TO|IN_DELETE);
if (k < 0) {
close_nointr_nofail(fd);
return -errno;
commit 5caef0fc192e88b2d965da50900567046e186ce1
Author: Lennart Poettering <lennart at poettering.net>
Date: Thu Jun 20 04:00:28 2013 +0200
logind: make ListMachines bus call public
diff --git a/src/login/org.freedesktop.login1.conf b/src/login/org.freedesktop.login1.conf
index 6c1f2f5..0407609 100644
--- a/src/login/org.freedesktop.login1.conf
+++ b/src/login/org.freedesktop.login1.conf
@@ -62,6 +62,10 @@
<allow send_destination="org.freedesktop.login1"
send_interface="org.freedesktop.login1.Manager"
+ send_member="ListMachines"/>
+
+ <allow send_destination="org.freedesktop.login1"
+ send_interface="org.freedesktop.login1.Manager"
send_member="ListSeats"/>
<allow send_destination="org.freedesktop.login1"
More information about the systemd-commits
mailing list