1 /*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/
4 This file is part of systemd.
6 Copyright 2013 Lennart Poettering
8 systemd is free software; you can redistribute it and/or modify it
9 under the terms of the GNU Lesser General Public License as published by
10 the Free Software Foundation; either version 2.1 of the License, or
11 (at your option) any later version.
13 systemd is distributed in the hope that it will be useful, but
14 WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 Lesser General Public License for more details.
18 You should have received a copy of the GNU Lesser General Public License
19 along with systemd; If not, see <http://www.gnu.org/licenses/>.
22 #ifdef HAVE_VALGRIND_MEMCHECK_H
23 #include <valgrind/memcheck.h>
32 #include "bus-internal.h"
33 #include "bus-message.h"
34 #include "bus-control.h"
36 int sd_bus_get_unique_name(sd_bus *bus, const char **unique) {
43 if (bus_pid_changed(bus))
46 r = bus_ensure_running(bus);
50 *unique = bus->unique_name;
54 int sd_bus_request_name(sd_bus *bus, const char *name, int flags) {
55 _cleanup_bus_message_unref_ sd_bus_message *reply = NULL;
65 if (!BUS_IS_OPEN(bus->state))
67 if (bus_pid_changed(bus))
71 struct kdbus_cmd_name *n;
75 n = alloca0(offsetof(struct kdbus_cmd_name, name) + l + 1);
76 n->size = offsetof(struct kdbus_cmd_name, name) + l + 1;
77 n->name_flags = flags;
78 memcpy(n->name, name, l+1);
80 #ifdef HAVE_VALGRIND_MEMCHECK_H
81 VALGRIND_MAKE_MEM_DEFINED(n, n->size);
84 r = ioctl(bus->input_fd, KDBUS_CMD_NAME_ACQUIRE, n);
90 r = sd_bus_call_method(
92 "org.freedesktop.DBus",
94 "org.freedesktop.DBus",
104 r = sd_bus_message_read(reply, "u", &ret);
112 int sd_bus_release_name(sd_bus *bus, const char *name) {
113 _cleanup_bus_message_unref_ sd_bus_message *reply = NULL;
121 if (!bus->bus_client)
123 if (!BUS_IS_OPEN(bus->state))
125 if (bus_pid_changed(bus))
128 if (bus->is_kernel) {
129 struct kdbus_cmd_name *n;
133 n = alloca0(offsetof(struct kdbus_cmd_name, name) + l + 1);
134 n->size = offsetof(struct kdbus_cmd_name, name) + l + 1;
135 memcpy(n->name, name, l+1);
137 #ifdef HAVE_VALGRIND_MEMCHECK_H
138 VALGRIND_MAKE_MEM_DEFINED(n, n->size);
140 r = ioctl(bus->input_fd, KDBUS_CMD_NAME_RELEASE, n);
144 return n->name_flags;
146 r = sd_bus_call_method(
148 "org.freedesktop.DBus",
150 "org.freedesktop.DBus",
159 r = sd_bus_message_read(reply, "u", &ret);
167 int sd_bus_list_names(sd_bus *bus, char ***l) {
168 _cleanup_bus_message_unref_ sd_bus_message *reply1 = NULL, *reply2 = NULL;
176 if (!BUS_IS_OPEN(bus->state))
178 if (bus_pid_changed(bus))
181 r = sd_bus_call_method(
183 "org.freedesktop.DBus",
185 "org.freedesktop.DBus",
193 r = sd_bus_call_method(
195 "org.freedesktop.DBus",
197 "org.freedesktop.DBus",
198 "ListActivatableNames",
205 r = bus_message_read_strv_extend(reply1, &x);
211 r = bus_message_read_strv_extend(reply2, &x);
221 int sd_bus_get_owner(sd_bus *bus, const char *name, char **owner) {
222 _cleanup_bus_message_unref_ sd_bus_message *reply = NULL;
230 if (!BUS_IS_OPEN(bus->state))
232 if (bus_pid_changed(bus))
235 r = sd_bus_call_method(
237 "org.freedesktop.DBus",
239 "org.freedesktop.DBus",
248 r = sd_bus_message_read(reply, "s", &found);
265 int sd_bus_get_owner_uid(sd_bus *bus, const char *name, uid_t *uid) {
266 _cleanup_bus_message_unref_ sd_bus_message *reply = NULL;
276 if (!BUS_IS_OPEN(bus->state))
278 if (bus_pid_changed(bus))
281 r = sd_bus_call_method(
283 "org.freedesktop.DBus",
285 "org.freedesktop.DBus",
286 "GetConnectionUnixUser",
294 r = sd_bus_message_read(reply, "u", &u);
302 int sd_bus_get_owner_pid(sd_bus *bus, const char *name, pid_t *pid) {
303 _cleanup_bus_message_unref_ sd_bus_message *reply = NULL;
313 if (!BUS_IS_OPEN(bus->state))
315 if (bus_pid_changed(bus))
318 r = sd_bus_call_method(
320 "org.freedesktop.DBus",
322 "org.freedesktop.DBus",
323 "GetConnectionUnixProcessID",
331 r = sd_bus_message_read(reply, "u", &u);
342 int bus_add_match_internal(sd_bus *bus, const char *match) {
346 return sd_bus_call_method(
348 "org.freedesktop.DBus",
350 "org.freedesktop.DBus",
358 int bus_remove_match_internal(sd_bus *bus, const char *match) {
362 return sd_bus_call_method(
364 "org.freedesktop.DBus",
366 "org.freedesktop.DBus",
374 int sd_bus_get_owner_machine_id(sd_bus *bus, const char *name, sd_id128_t *machine) {
375 _cleanup_bus_message_unref_ sd_bus_message *reply = NULL;
383 if (!BUS_IS_OPEN(bus->state))
385 if (bus_pid_changed(bus))
388 if (streq_ptr(name, bus->unique_name))
389 return sd_id128_get_machine(machine);
391 r = sd_bus_call_method(bus,
394 "org.freedesktop.DBus.Peer",
403 r = sd_bus_message_read(reply, "s", &mid);
407 return sd_id128_from_string(mid, machine);