chiark / gitweb /
bus: decorate API calls with gcc attributes where appropriate
[elogind.git] / src / systemd / sd-bus.h
1 /*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/
2
3 #ifndef foosdbushfoo
4 #define foosdbushfoo
5
6 /***
7   This file is part of systemd.
8
9   Copyright 2013 Lennart Poettering
10
11   systemd is free software; you can redistribute it and/or modify it
12   under the terms of the GNU Lesser General Public License as published by
13   the Free Software Foundation; either version 2.1 of the License, or
14   (at your option) any later version.
15
16   systemd is distributed in the hope that it will be useful, but
17   WITHOUT ANY WARRANTY; without even the implied warranty of
18   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
19   Lesser General Public License for more details.
20
21   You should have received a copy of the GNU Lesser General Public License
22   along with systemd; If not, see <http://www.gnu.org/licenses/>.
23 ***/
24
25 #include <inttypes.h>
26 #include <sys/types.h>
27
28 #include <sd-id128.h>
29
30 #ifdef __cplusplus
31 extern "C" {
32 #endif
33
34 #ifndef _sd_printf_attr_
35 #  if __GNUC__ >= 4
36 #    define _sd_printf_attr_(a,b) __attribute__ ((format (printf, a, b)))
37 #  else
38 #    define _sd_printf_attr_(a,b)
39 #  endif
40 #endif
41
42 #ifndef _sd_sentinel_attr_
43 #  define _sd_sentinel_attr_ __attribute__((sentinel))
44 #endif
45
46 /* Types */
47
48 typedef struct sd_bus sd_bus;
49 typedef struct sd_bus_message sd_bus_message;
50
51 typedef struct {
52         const char *name;
53         const char *message;
54         int need_free;
55 } sd_bus_error;
56
57 /* Callbacks */
58
59 typedef int (*sd_bus_message_handler_t)(sd_bus *bus, sd_bus_message *m, void *userdata);
60
61 typedef int (*sd_bus_property_get_t) (sd_bus *bus, const char *path, const char *interface, const char *property, sd_bus_message *reply, sd_bus_error *error, void *userdata);
62 typedef int (*sd_bus_property_set_t) (sd_bus *bus, const char *path, const char *interface, const char *property, sd_bus_message *value, sd_bus_error *error, void *userdata);
63
64 typedef int (*sd_bus_object_find_t) (sd_bus *bus, const char *path, const char *interface, void **found, void *userdata);
65
66 typedef int (*sd_bus_node_enumerator_t) (sd_bus *bus, const char *path, char ***nodes, void *userdata);
67
68 #include "sd-bus-protocol.h"
69 #include "sd-bus-vtable.h"
70 #include "sd-memfd.h"
71
72 /* Connections */
73
74 int sd_bus_open_system(sd_bus **ret);
75 int sd_bus_open_user(sd_bus **ret);
76
77 int sd_bus_new(sd_bus **ret);
78 int sd_bus_set_address(sd_bus *bus, const char *address);
79 int sd_bus_set_fd(sd_bus *bus, int input_fd, int output_fd);
80 int sd_bus_set_exec(sd_bus *bus, const char *path, char *const argv[]);
81 int sd_bus_set_bus_client(sd_bus *bus, int b);
82 int sd_bus_set_server(sd_bus *bus, int b, sd_id128_t server_id);
83 int sd_bus_set_anonymous(sd_bus *bus, int b);
84 int sd_bus_negotiate_fds(sd_bus *bus, int b);
85 int sd_bus_negotiate_attach_comm(sd_bus *bus, int b);
86 int sd_bus_negotiate_attach_exe(sd_bus *bus, int b);
87 int sd_bus_negotiate_attach_cmdline(sd_bus *bus, int b);
88 int sd_bus_negotiate_attach_cgroup(sd_bus *bus, int b);
89 int sd_bus_negotiate_attach_caps(sd_bus *bus, int b);
90 int sd_bus_negotiate_attach_selinux_context(sd_bus *bus, int b);
91 int sd_bus_negotiate_attach_audit(sd_bus *bus, int b);
92 int sd_bus_start(sd_bus *ret);
93
94 void sd_bus_close(sd_bus *bus);
95
96 sd_bus *sd_bus_ref(sd_bus *bus);
97 sd_bus *sd_bus_unref(sd_bus *bus);
98
99 int sd_bus_is_open(sd_bus *bus);
100 int sd_bus_can_send(sd_bus *bus, char type);
101 int sd_bus_get_server_id(sd_bus *bus, sd_id128_t *peer);
102
103 int sd_bus_send(sd_bus *bus, sd_bus_message *m, uint64_t *serial);
104 int sd_bus_send_with_reply(sd_bus *bus, sd_bus_message *m, sd_bus_message_handler_t callback, void *userdata, uint64_t usec, uint64_t *serial);
105 int sd_bus_send_with_reply_cancel(sd_bus *bus, uint64_t serial);
106 int sd_bus_send_with_reply_and_block(sd_bus *bus, sd_bus_message *m, uint64_t usec, sd_bus_error *error, sd_bus_message **r);
107
108 int sd_bus_get_fd(sd_bus *bus);
109 int sd_bus_get_events(sd_bus *bus);
110 int sd_bus_get_timeout(sd_bus *bus, uint64_t *timeout_usec);
111 int sd_bus_process(sd_bus *bus, sd_bus_message **r);
112 int sd_bus_wait(sd_bus *bus, uint64_t timeout_usec);
113 int sd_bus_flush(sd_bus *bus);
114
115 int sd_bus_add_filter(sd_bus *bus, sd_bus_message_handler_t callback, void *userdata);
116 int sd_bus_remove_filter(sd_bus *bus, sd_bus_message_handler_t callback, void *userdata);
117
118 int sd_bus_add_match(sd_bus *bus, const char *match, sd_bus_message_handler_t callback, void *userdata);
119 int sd_bus_remove_match(sd_bus *bus, const char *match, sd_bus_message_handler_t callback, void *userdata);
120
121 int sd_bus_add_object(sd_bus *bus, const char *path, sd_bus_message_handler_t callback, void *userdata);
122 int sd_bus_remove_object(sd_bus *bus, const char *path, sd_bus_message_handler_t callback, void *userdata);
123
124 int sd_bus_add_fallback(sd_bus *bus, const char *prefix, sd_bus_message_handler_t callback, void *userdata);
125 int sd_bus_remove_fallback(sd_bus *bus, const char *prefix, sd_bus_message_handler_t callback, void *userdata);
126
127 int sd_bus_add_object_vtable(sd_bus *bus, const char *path, const char *interface, const sd_bus_vtable *vtable, void *userdata);
128 int sd_bus_remove_object_vtable(sd_bus *bus, const char *path, const char *interface);
129
130 int sd_bus_add_fallback_vtable(sd_bus *bus, const char *path, const char *interface, const sd_bus_vtable *vtable, sd_bus_object_find_t find, void *userdata);
131 int sd_bus_remove_fallback_vtable(sd_bus *bus, const char *path, const char *interface);
132
133 int sd_bus_add_node_enumerator(sd_bus *bus, const char *path, sd_bus_node_enumerator_t callback, void *userdata);
134 int sd_bus_remove_node_enumerator(sd_bus *bus, const char *path, sd_bus_node_enumerator_t callback, void *userdata);
135
136 int sd_bus_add_object_manager(sd_bus *bus, const char *path);
137 int sd_bus_remove_object_manager(sd_bus *bus, const char *path);
138
139 /* Message object */
140 int sd_bus_message_new_signal(sd_bus *bus, const char *path, const char *interface, const char *member, sd_bus_message **m);
141 int sd_bus_message_new_method_call(sd_bus *bus, const char *destination, const char *path, const char *interface, const char *member, sd_bus_message **m);
142 int sd_bus_message_new_method_return(sd_bus *bus, sd_bus_message *call, sd_bus_message **m);
143 int sd_bus_message_new_method_error(sd_bus *bus, sd_bus_message *call, const sd_bus_error *e, sd_bus_message **m);
144 int sd_bus_message_new_method_errorf(sd_bus *bus, sd_bus_message *call, sd_bus_message **m, const char *name, const char *format, ...) _sd_printf_attr_(5, 0);
145
146 sd_bus_message* sd_bus_message_ref(sd_bus_message *m);
147 sd_bus_message* sd_bus_message_unref(sd_bus_message *m);
148
149 int sd_bus_message_get_type(sd_bus_message *m, uint8_t *type);
150 int sd_bus_message_get_serial(sd_bus_message *m, uint64_t *serial);
151 int sd_bus_message_get_reply_serial(sd_bus_message *m, uint64_t *serial);
152 int sd_bus_message_get_no_reply(sd_bus_message *m);
153
154 const char *sd_bus_message_get_path(sd_bus_message *m);
155 const char *sd_bus_message_get_interface(sd_bus_message *m);
156 const char *sd_bus_message_get_member(sd_bus_message *m);
157 const char *sd_bus_message_get_destination(sd_bus_message *m);
158 const char *sd_bus_message_get_sender(sd_bus_message *m);
159 const sd_bus_error *sd_bus_message_get_error(sd_bus_message *m);
160
161 int sd_bus_message_get_monotonic_timestamp(sd_bus_message *m, uint64_t *usec);
162 int sd_bus_message_get_realtime_timestamp(sd_bus_message *m, uint64_t *usec);
163 int sd_bus_message_get_uid(sd_bus_message *m, uid_t *uid);
164 int sd_bus_message_get_gid(sd_bus_message *m, gid_t *gid);
165 int sd_bus_message_get_pid(sd_bus_message *m, pid_t *pid);
166 int sd_bus_message_get_tid(sd_bus_message *m, pid_t *tid);
167 int sd_bus_message_get_pid_starttime(sd_bus_message *m, uint64_t *usec);
168 int sd_bus_message_get_selinux_context(sd_bus_message *m, const char **r);
169 int sd_bus_message_get_comm(sd_bus_message *m, const char **r);
170 int sd_bus_message_get_tid_comm(sd_bus_message *m, const char **r);
171 int sd_bus_message_get_exe(sd_bus_message *m, const char **r);
172 int sd_bus_message_get_cgroup(sd_bus_message *m, const char **r);
173 int sd_bus_message_get_cmdline(sd_bus_message *m, char ***cmdline);
174 int sd_bus_message_get_unit(sd_bus_message *m, const char **unit);
175 int sd_bus_message_get_user_unit(sd_bus_message *m, const char **unit);
176 int sd_bus_message_get_session(sd_bus_message *m, const char **session);
177 int sd_bus_message_get_owner_uid(sd_bus_message *m, uid_t *uid);
178 int sd_bus_message_get_audit_sessionid(sd_bus_message *m, uint32_t *sessionid);
179 int sd_bus_message_get_audit_loginuid(sd_bus_message *m, uid_t *loginuid);
180 int sd_bus_message_has_effective_cap(sd_bus_message *m, int capability);
181
182 int sd_bus_message_is_signal(sd_bus_message *m, const char *interface, const char *member);
183 int sd_bus_message_is_method_call(sd_bus_message *m, const char *interface, const char *member);
184 int sd_bus_message_is_method_error(sd_bus_message *m, const char *name);
185
186 int sd_bus_message_set_no_reply(sd_bus_message *m, int b);
187 int sd_bus_message_set_destination(sd_bus_message *m, const char *destination);
188
189 int sd_bus_message_append(sd_bus_message *m, const char *types, ...);
190 int sd_bus_message_append_basic(sd_bus_message *m, char type, const void *p);
191 int sd_bus_message_append_array(sd_bus_message *m, char type, const void *ptr, size_t size);
192 int sd_bus_message_append_array_space(sd_bus_message *m, char type, size_t size, void **ptr);
193 int sd_bus_message_append_array_memfd(sd_bus_message *m, char type, sd_memfd *memfd);
194 int sd_bus_message_append_string_space(sd_bus_message *m, size_t size, char **s);
195 int sd_bus_message_append_string_memfd(sd_bus_message *m, sd_memfd* memfd);
196 int sd_bus_message_open_container(sd_bus_message *m, char type, const char *contents);
197 int sd_bus_message_close_container(sd_bus_message *m);
198
199 int sd_bus_message_read(sd_bus_message *m, const char *types, ...);
200 int sd_bus_message_read_basic(sd_bus_message *m, char type, void *p);
201 int sd_bus_message_read_array(sd_bus_message *m, char type, const void **ptr, size_t *size);
202 int sd_bus_message_enter_container(sd_bus_message *m, char type, const char *contents);
203 int sd_bus_message_exit_container(sd_bus_message *m);
204 int sd_bus_message_peek_type(sd_bus_message *m, char *type, const char **contents);
205 int sd_bus_message_rewind(sd_bus_message *m, int complete);
206
207 int sd_bus_message_get_signature(sd_bus_message *m, int complete, const char **signature);
208
209 /* Convenience calls */
210
211 int sd_bus_call_method(sd_bus *bus, const char *destination, const char *path, const char *interface, const char *member, sd_bus_error *error, sd_bus_message **reply, const char *types, ...);
212 int sd_bus_get_property(sd_bus *bus, const char *destination, const char *path, const char *interface, const char *member, sd_bus_error *error, sd_bus_message **reply, const char *type);
213 int sd_bus_set_property(sd_bus *bus, const char *destination, const char *path, const char *interface, const char *member, sd_bus_error *error, const char *type, ...);
214 int sd_bus_reply_method_return(sd_bus *bus, sd_bus_message *call, const char *types, ...);
215 int sd_bus_reply_method_error(sd_bus *bus, sd_bus_message *call, const sd_bus_error *e);
216 int sd_bus_reply_method_errorf(sd_bus *bus, sd_bus_message *call, const char *name, const char *format, ...) _sd_printf_attr_(4, 0);
217
218 int sd_bus_emit_signal(sd_bus *bus, const char *path, const char *interface, const char *member, const char *types, ...);
219
220 int sd_bus_emit_properties_changed_strv(sd_bus *bus, const char *path, const char *interface, char **names);
221 int sd_bus_emit_properties_changed(sd_bus *bus, const char *path, const char *interface, const char *name, ...) _sd_sentinel_attr_;
222
223 int sd_bus_emit_interfaces_added_strv(sd_bus *bus, const char *path, char **interfaces);   /* MISSING */
224 int sd_bus_emit_interfaces_added(sd_bus *bus, const char *path, const char *interface, ...) _sd_sentinel_attr_;   /* MISSING */
225 int sd_bus_emit_interfaces_removed_strv(sd_bus *bus, const char *path, char **interfaces);  /* MISSING */
226 int sd_bus_emit_interfaces_removed(sd_bus *bus, const char *path, const char *interface, ...) _sd_sentinel_attr_;  /* MISSING */
227
228 /* Bus management */
229
230 int sd_bus_get_unique_name(sd_bus *bus, const char **unique);
231 int sd_bus_request_name(sd_bus *bus, const char *name, int flags);
232 int sd_bus_release_name(sd_bus *bus, const char *name);
233 int sd_bus_list_names(sd_bus *bus, char ***l);
234 int sd_bus_get_owner(sd_bus *bus, const char *name, char **owner);
235 int sd_bus_get_owner_uid(sd_bus *bus, const char *name, uid_t *uid);
236 int sd_bus_get_owner_pid(sd_bus *bus, const char *name, pid_t *pid);
237 int sd_bus_get_owner_machine_id(sd_bus *bus, const char *name, sd_id128_t *machine);
238
239 /* Error structures */
240
241 #define SD_BUS_ERROR_NULL ((sd_bus_error) {NULL, NULL, 0})
242 #define SD_BUS_ERROR_MAKE(name, message) ((sd_bus_error) {(name), (message), 0})
243
244 void sd_bus_error_free(sd_bus_error *e);
245 int sd_bus_error_setf(sd_bus_error *e, const char *name, const char *format, ...)  _sd_printf_attr_(3, 0);
246 int sd_bus_error_set(sd_bus_error *e, const char *name, const char *message);
247 void sd_bus_error_set_const(sd_bus_error *e, const char *name, const char *message);
248 int sd_bus_error_copy(sd_bus_error *dest, const sd_bus_error *e);
249 int sd_bus_error_is_set(const sd_bus_error *e);
250 int sd_bus_error_has_name(const sd_bus_error *e, const char *name);
251
252 #define SD_BUS_APPEND_ID128(x) 16,                                          \
253                 (x).bytes[0],  (x).bytes[1],  (x).bytes[2],  (x).bytes[3],  \
254                 (x).bytes[4],  (x).bytes[5],  (x).bytes[6],  (x).bytes[7],  \
255                 (x).bytes[8],  (x).bytes[9],  (x).bytes[10], (x).bytes[11], \
256                 (x).bytes[12], (x).bytes[13], (x).bytes[14], (x).bytes[15]
257
258 #ifdef __cplusplus
259 }
260 #endif
261
262 #endif