From: Lennart Poettering Date: Tue, 3 Jan 2012 19:51:38 +0000 (+0100) Subject: login: introduce sd_pid_get_service() X-Git-Tag: v38~102 X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=commitdiff_plain;h=9847946e12479b27d3ebfd024f00a6ac33ce73d3 login: introduce sd_pid_get_service() --- diff --git a/Makefile.am b/Makefile.am index 225c6fc36..651b37df0 100644 --- a/Makefile.am +++ b/Makefile.am @@ -20,9 +20,9 @@ ACLOCAL_AMFLAGS = -I m4 SUBDIRS = po -LIBSYSTEMD_LOGIN_CURRENT=0 -LIBSYSTEMD_LOGIN_REVISION=6 -LIBSYSTEMD_LOGIN_AGE=0 +LIBSYSTEMD_LOGIN_CURRENT=1 +LIBSYSTEMD_LOGIN_REVISION=0 +LIBSYSTEMD_LOGIN_AGE=1 LIBSYSTEMD_DAEMON_CURRENT=0 LIBSYSTEMD_DAEMON_REVISION=0 @@ -1910,6 +1910,7 @@ MANPAGES_ALIAS += \ man/sd_session_get_uid.3 \ man/sd_session_get_seat.3 \ man/sd_pid_get_owner_uid.3 \ + man/sd_pid_get_service.3 \ man/sd_uid_is_on_seat.3 \ man/sd_uid_get_sessions.3 \ man/sd_uid_get_seats.3 \ @@ -1924,6 +1925,7 @@ man/sd_login_monitor_get_fd.3: man/sd_login_monitor_new.3 man/sd_session_get_uid.3: man/sd_session_is_active.3 man/sd_session_get_seat.3: man/sd_session_is_active.3 man/sd_pid_get_owner_uid.3: man/sd_pid_get_session.3 +man/sd_pid_get_session.3: man/sd_pid_get_session.3 man/sd_uid_is_on_seat.3: man/sd_uid_get_state.3 man/sd_uid_get_sessions.3: man/sd_uid_get_state.3 man/sd_uid_get_seats.3: man/sd_uid_get_state.3 diff --git a/man/sd_pid_get_session.xml b/man/sd_pid_get_session.xml index 24e468015..4086c5a82 100644 --- a/man/sd_pid_get_session.xml +++ b/man/sd_pid_get_session.xml @@ -44,8 +44,9 @@ sd_pid_get_session + sd_pid_get_service sd_pid_get_owner_uid - Determine session or owner of a session of a specific PID + Determine session, service or owner of a session of a specific PID @@ -58,6 +59,12 @@ char** session + + int sd_pid_get_service + pid_t pid + char** service + + int sd_pid_get_owner_uid pid_t pid @@ -75,11 +82,23 @@ identifier. The session identifier is a short string, suitable for usage in file system paths. Note that not all processes are part of a login session (e.g. system - service processes and user processes that are shared - between multiple sessions of the same user). For - processes not being part of a login session this - function will fail. The returned string needs to be - freed with the libc + service processes, user processes that are shared + between multiple sessions of the same user, or kernel + threads). For processes not being part of a login + session this function will fail. The returned string + needs to be freed with the libc + free3 + call after use. + + sd_pid_get_service() may be + used to determine the system service identifier of a + process identified by the specified process + identifier. The service name is a short string, + suitable for usage in file system paths. Note that not + all processes are part of a service (e.g. user + processes, or kernel threads). For processes not being + part of a system service this function will fail. The + returned string needs to be freed with the libc free3 call after use. @@ -106,10 +125,11 @@ Notes - The sd_pid_get_session() - and sd_pid_get_owner_uid() - interfaces are available as shared library, which can - be compiled and linked to with the + The sd_pid_get_session(), + sd_pid_get_service(), and + sd_pid_get_owner_uid() interfaces + are available as shared library, which can be compiled + and linked to with the libsystemd-login pkg-config1 file. diff --git a/src/login/libsystemd-login.sym b/src/login/libsystemd-login.sym index 0d51fa76e..bac46f406 100644 --- a/src/login/libsystemd-login.sym +++ b/src/login/libsystemd-login.sym @@ -33,3 +33,8 @@ global: local: *; }; + +LIBSYSTEMD_LOGIN_38 { +global: + sd_pid_get_service; +} LIBSYSTEMD_LOGIN_31; diff --git a/src/login/sd-login.c b/src/login/sd-login.c index a0a56c495..1d4368187 100644 --- a/src/login/sd-login.c +++ b/src/login/sd-login.c @@ -121,6 +121,33 @@ _public_ int sd_pid_get_session(pid_t pid, char **session) { return 0; } +_public_ int sd_pid_get_service(pid_t pid, char **service) { + int r; + char *cgroup, *p; + + if (!service) + return -EINVAL; + + r = pid_get_cgroup(pid, NULL, &cgroup); + if (r < 0) + return r; + + if (!startswith(cgroup, "/system/")) { + free(cgroup); + return -ENOENT; + } + + p = cgroup + 8; + p = strndup(p, strcspn(p, "/")); + free(cgroup); + + if (!p) + return -ENOMEM; + + *service = p; + return 0; +} + _public_ int sd_pid_get_owner_uid(pid_t pid, uid_t *uid) { int r; char *root, *cgroup, *p, *cc; diff --git a/src/login/sd-login.h b/src/login/sd-login.h index 0cb0bf06b..1d8a55e90 100644 --- a/src/login/sd-login.h +++ b/src/login/sd-login.h @@ -53,6 +53,10 @@ int sd_pid_get_session(pid_t pid, char **session); * return an error for system processes. */ int sd_pid_get_owner_uid(pid_t pid, uid_t *uid); +/* Get service name from PID. This will return an error for + * non-service processes. */ +int sd_pid_get_service(pid_t, char **service); + /* Get state from uid. Possible states: offline, lingering, online, active */ int sd_uid_get_state(uid_t uid, char**state);