sd_bus_creds_get_pid
systemd
A monkey with a typewriter
Zbigniew
Jędrzejewski-Szmek
zbyszek@in.waw.pl
sd_bus_creds_get_pid
3
sd_bus_creds_get_pid
sd_bus_creds_get_pid_starttime
sd_bus_creds_get_tid
sd_bus_creds_get_uid
sd_bus_creds_get_gid
sd_bus_creds_get_comm
sd_bus_creds_get_tid_comm
sd_bus_creds_get_exe
sd_bus_creds_get_cmdline
sd_bus_creds_get_cgroup
sd_bus_creds_get_unit
sd_bus_creds_get_user_unit
sd_bus_creds_get_slice
sd_bus_creds_get_session
sd_bus_creds_get_owner_uid
sd_bus_creds_has_effective_cap
sd_bus_creds_has_permitted_cap
sd_bus_creds_has_inheritable_cap
sd_bus_creds_has_bounding_cap
sd_bus_creds_get_selinux_context
sd_bus_creds_get_audit_session_id
sd_bus_creds_get_audit_login_uid
sd_bus_creds_get_unique_name
sd_bus_creds_get_well_known_names
Retrieve fields from a credentials object
#include <systemd/sd-bus.h>
int sd_bus_creds_get_pid
sd_bus_creds *c
pid_t *pid
int sd_bus_creds_get_pid_starttime
sd_bus_creds *c
uint64_t *usec
int sd_bus_creds_get_tid
sd_bus_creds *c
pid_t *tid
int sd_bus_creds_get_pid
sd_bus_creds *c
uid_t *uid
int sd_bus_creds_get_gid
sd_bus_creds *c
gid_t *gid
int sd_bus_creds_get_comm
sd_bus_creds *c
const char **comm
int sd_bus_creds_get_tid_comm
sd_bus_creds *c
const char **comm
int sd_bus_creds_get_exe
sd_bus_creds *c
const char **exe
int sd_bus_creds_get_cmdline
sd_bus_creds *c
char ***cmdline
int sd_bus_creds_get_cgroup
sd_bus_creds *c
const char **cgroup
int sd_bus_creds_get_unit
sd_bus_creds *c
const char **unit
int sd_bus_creds_get_user_unit
sd_bus_creds *c
const char **unit
int sd_bus_creds_get_slice
sd_bus_creds *c
const char **slice
int sd_bus_creds_get_session
sd_bus_creds *c
const char **slice
int sd_bus_creds_get_owner_uid
sd_bus_creds *c
uid_t *uid
int sd_bus_creds_has_effective_cap
sd_bus_creds *c
int capability
int sd_bus_creds_has_permitted_cap
sd_bus_creds *c
int capability
int sd_bus_creds_has_inheritable_cap
sd_bus_creds *c
int capability
int sd_bus_creds_has_bounding_cap
sd_bus_creds *c
int capability
int sd_bus_creds_get_selinux_context
sd_bus_creds *c
const char **context
int sd_bus_creds_get_audit_session_id
sd_bus_creds *c
uint32_t *sessionid
int sd_bus_creds_get_audit_login_uid
sd_bus_creds *c
uid_t *loginuid
int sd_bus_creds_get_unique_name
sd_bus_creds *c
const char **name
int sd_bus_creds_get_well_known_names
sd_bus_creds *c
char ***name
Description
These functions return information from an
sd_bus_creds object. It may be created with
sd_bus_creds_new_from_pid3,
in which case it will describe the specified process, or it may be
created by
sd_bus_get_peer_creds3,
in which case it will describe the process at the other endpoint
of a connection.
sd_bus_creds_get_pid() will retrieve the
PID (process identifier).
sd_bus_creds_get_pid_starttime() will
retrieve the time since the start of the epoch in microseconds
since the process was started.
sd_bus_creds_get_tid() will retrieve the
TID (thread identifier).
sd_bus_creds_get_uid() will retrieve the
numeric UID (user identifier).
sd_bus_creds_get_gid() will retrieve the
numeric GID (group identifier).
sd_bus_creds_get_comm() will retrieve the
comm field (truncated name of the executable, as stored in
/proc/pid/comm).
sd_bus_creds_get_tid_comm() will retrieve
the comm field of the thread (as stored in
/proc/pid/task/tid/comm).
sd_bus_creds_get_exe() will retrieve the
path to the program (as stored in the
/proc/pid/exe
link, but with (deleted) suffix removed).
sd_bus_creds_get_cmdline() will retrieve
an array of command-line arguments (as stored in
/proc/pid/cmdline).
sd_bus_creds_get_cgroup() will retrieve
the cgroup path. See cgroups.txt.
sd_bus_creds_get_unit() will retrieve the
systemd unit name (in the system instance of systemd) that the
process is part of. See
systemd.unit5.
sd_bus_creds_get_user_unit() will
retrieve the systemd unit name (in the user instance of systemd)
that the process is part of. See
systemd.unit5.
sd_bus_creds_get_slice() will retrieve
the systemd slice (a unit in the system instance of systemd) that
the process is part of. See
systemd.slice5.
sd_bus_creds_get_session() will retrieve
the logind session that the process is part of. See
systemd-logind.service8.
sd_bus_creds_get_owner_uid() will retrieve
the numeric UID (user identifier) of the user who owns the slice
that the process is part of. See
systemd.slice5
.
sd_bus_creds_has_effective_cap() will
check whether the capability specified by
capability was set in the effective
capabilities mask. A positive return value means that is was
set, zero means that it was not set, and a negative return
value signifies an error. See
capabilities7
and Capabilities= and
CapabilityBoundingSet= settings in
systemd.exec5.
sd_bus_creds_has_permitted_cap() is
similar to sd_bus_creds_has_effective_cap(),
but will check the permitted capabilities mask.
sd_bus_creds_has_inheritable_cap() is
similar to sd_bus_creds_has_effective_cap(),
but will check the inheritable capabilities mask.
sd_bus_creds_has_bounding_cap() is
similar to sd_bus_creds_has_effective_cap(),
but will check the bounding capabilities mask.
sd_bus_creds_get_selinux_context() will
retrieve the SELinux security context (label) of the process.
sd_bus_creds_get_audit_session_id() will
retrieve the audit session identifier of the process.
sd_bus_creds_get_audit_login_uid() will
retrieve the audit user login identifier (the identifier of the
user who is "responsible" for the session).
sd_bus_creds_get_unique_name() will
retrieve the D-Bus unique name. See The
D-Bus specification.
sd_bus_creds_get_well_known_names() will
retrieve the set of D-Bus well-known names. See The
D-Bus specification.
All functions that take a const
char** parameter will store the answer there as an
address of a NUL-terminated string. It will be valid as long as
c remains valid, and should not be freed or
modified by the caller.
All functions that take a char***
parameter will store the answer there as an address of a an array
of strings. Each invidividual string is NUL-terminated, and the
array is NULL-terminated as a whole. It will be valid as long as
c remains valid, and should not be freed or
modified by the caller.
Return Value
On success, these calls return 0 or a positive integer. On
failure, these calls return a negative errno-style error code.
Errors
Returned errors may indicate the following problems:
-ENODATA
Given field is not available in
c.
-ENOENT
Given field is not specified for the sender.
This will be returned by sd_bus_get_unit(),
sd_bus_get_user_unit(),
sd_bus_get_slice(),
sd_bus_get_session(), and
sd_bus_get_owner_uid() if the sender is not
part of a systemd system unit, systemd user unit, systemd
slice, logind session, or a systemd user session.
-ENXIO
An error occurred in parsing cgroup paths.
libsystemd might be out of sync with
the running systemd version.
-EINVAL
Specified pointer parameter is NULL.
-ENOMEM
Memory allocation failed.
Notes
sd_bus_open_user() and other functions
described here are available as a shared library, which can be
compiled and linked to with the
libsystemd pkg-config1
file.
See Also
systemd1,
sd-bus3,
fork2,
execve2,
credentials7,
free3,
proc5,
systemd.journald-fields7