X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;ds=sidebyside;f=src%2Flibsystemd%2Fsd-login%2Fsd-login.c;h=d1478ddb785a43703dd61dc479d616306a9e3a3b;hb=620a687cd2b27e93e289e057aad0e57f30651bf9;hp=e7eea19580cb221c9bea3a12ee1aaaeca36e6cd9;hpb=de0671ee7fe465e108f62dcbbbe9366f81dd9e9a;p=elogind.git diff --git a/src/libsystemd/sd-login/sd-login.c b/src/libsystemd/sd-login/sd-login.c index e7eea1958..d1478ddb7 100644 --- a/src/libsystemd/sd-login/sd-login.c +++ b/src/libsystemd/sd-login/sd-login.c @@ -165,6 +165,15 @@ _public_ int sd_peer_get_slice(int fd, char **slice) { return cg_pid_get_slice(ucred.pid, slice); } +static int file_of_uid(uid_t uid, char **p) { + assert(p); + + if (asprintf(p, "/run/systemd/users/" UID_FMT, uid) < 0) + return -ENOMEM; + + return 0; +} + _public_ int sd_uid_get_state(uid_t uid, char**state) { _cleanup_free_ char *p = NULL; char *s = NULL; @@ -172,8 +181,9 @@ _public_ int sd_uid_get_state(uid_t uid, char**state) { assert_return(state, -EINVAL); - if (asprintf(&p, "/run/systemd/users/"UID_FMT, uid) < 0) - return -ENOMEM; + r = file_of_uid(uid, &p); + if (r < 0) + return r; r = parse_env_file(p, NEWLINE, "STATE", &s, NULL); if (r == -ENOENT) { @@ -192,6 +202,29 @@ _public_ int sd_uid_get_state(uid_t uid, char**state) { return 0; } +_public_ int sd_uid_get_display(uid_t uid, char **session) { + _cleanup_free_ char *p = NULL, *s = NULL; + int r; + + assert_return(session, -EINVAL); + + r = file_of_uid(uid, &p); + if (r < 0) + return r; + + r = parse_env_file(p, NEWLINE, "DISPLAY", &s, NULL); + if (r < 0) + return r; + + if (isempty(s)) + return -ENOENT; + + *session = s; + s = NULL; + + return 0; +} + _public_ int sd_uid_is_on_seat(uid_t uid, int require_active, const char *seat) { char *w, *state; _cleanup_free_ char *t = NULL, *s = NULL, *p = NULL; @@ -231,8 +264,9 @@ static int uid_get_array(uid_t uid, const char *variable, char ***array) { char **a; int r; - if (asprintf(&p, "/run/systemd/users/"UID_FMT, uid) < 0) - return -ENOMEM; + r = file_of_uid(uid, &p); + if (r < 0) + return r; r = parse_env_file(p, NEWLINE, variable, &s, @@ -362,7 +396,6 @@ _public_ int sd_session_get_state(const char *session, char **state) { return r; r = parse_env_file(p, NEWLINE, "STATE", &s, NULL); - if (r < 0) return r; else if (!s) @@ -405,7 +438,6 @@ static int session_get_string(const char *session, const char *field, char **val return r; r = parse_env_file(p, NEWLINE, field, &s, NULL); - if (r < 0) return r; @@ -738,7 +770,7 @@ _public_ int sd_machine_get_class(const char *machine, char **class) { const char *p; int r; - assert_return(filename_is_safe(machine), -EINVAL); + assert_return(machine_name_is_valid(machine), -EINVAL); assert_return(class, -EINVAL); p = strappenda("/run/systemd/machines/", machine);