chiark / gitweb /
bus: add API for appending/reading fixed arrays
[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 #include "sd-bus-protocol.h"
30
31 #ifdef __cplusplus
32 extern "C" {
33 #endif
34
35 #ifndef _sd_printf_attr_
36 #  if __GNUC__ >= 4
37 #    define _sd_printf_attr_(a,b) __attribute__ ((format (printf, a, b)))
38 #  else
39 #    define _sd_printf_attr_(a,b)
40 #  endif
41 #endif
42
43 /* TODO:
44  * - merge busctl into systemctl or so?
45  * - default policy (allow uid == 0 and our own uid)
46  * - enforce alignment of pointers passed in
47  * - negotiation for attach attributes
48  */
49
50 typedef struct sd_bus sd_bus;
51 typedef struct sd_bus_message sd_bus_message;
52
53 typedef struct {
54         const char *name;
55         const char *message;
56         int need_free;
57 } sd_bus_error;
58
59 typedef int (*sd_bus_message_handler_t)(sd_bus *bus, int ret, sd_bus_message *m, void *userdata);
60
61 /* Connections */
62
63 int sd_bus_open_system(sd_bus **ret);
64 int sd_bus_open_user(sd_bus **ret);
65
66 int sd_bus_new(sd_bus **ret);
67 int sd_bus_set_address(sd_bus *bus, const char *address);
68 int sd_bus_set_fd(sd_bus *bus, int input_fd, int output_fd);
69 int sd_bus_set_exec(sd_bus *bus, const char *path, char *const argv[]);
70 int sd_bus_set_bus_client(sd_bus *bus, int b);
71 int sd_bus_set_server(sd_bus *bus, int b, sd_id128_t server_id);
72 int sd_bus_set_anonymous(sd_bus *bus, int b);
73 int sd_bus_set_negotiate_fds(sd_bus *bus, int b);
74 int sd_bus_start(sd_bus *ret);
75
76 void sd_bus_close(sd_bus *bus);
77
78 sd_bus *sd_bus_ref(sd_bus *bus);
79 sd_bus *sd_bus_unref(sd_bus *bus);
80
81 int sd_bus_is_open(sd_bus *bus);
82 int sd_bus_can_send(sd_bus *bus, char type);
83 int sd_bus_get_server_id(sd_bus *bus, sd_id128_t *peer);
84
85 int sd_bus_send(sd_bus *bus, sd_bus_message *m, uint64_t *serial);
86 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);
87 int sd_bus_send_with_reply_cancel(sd_bus *bus, uint64_t serial);
88 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);
89
90 int sd_bus_get_fd(sd_bus *bus);
91 int sd_bus_get_events(sd_bus *bus);
92 int sd_bus_get_timeout(sd_bus *bus, uint64_t *timeout_usec);
93 int sd_bus_process(sd_bus *bus, sd_bus_message **r);
94 int sd_bus_wait(sd_bus *bus, uint64_t timeout_usec);
95 int sd_bus_flush(sd_bus *bus);
96
97 int sd_bus_add_filter(sd_bus *bus, sd_bus_message_handler_t callback, void *userdata);
98 int sd_bus_remove_filter(sd_bus *bus, sd_bus_message_handler_t callback, void *userdata);
99
100 int sd_bus_add_object(sd_bus *bus, const char *path, sd_bus_message_handler_t callback, void *userdata);
101 int sd_bus_remove_object(sd_bus *bus, const char *path, sd_bus_message_handler_t callback, void *userdata);
102
103 int sd_bus_add_fallback(sd_bus *bus, const char *prefix, sd_bus_message_handler_t callback, void *userdata);
104 int sd_bus_remove_fallback(sd_bus *bus, const char *prefix, sd_bus_message_handler_t callback, void *userdata);
105
106 int sd_bus_add_match(sd_bus *bus, const char *match, sd_bus_message_handler_t callback, void *userdata);
107 int sd_bus_remove_match(sd_bus *bus, const char *match, sd_bus_message_handler_t callback, void *userdata);
108
109 /* Message object */
110
111 int sd_bus_message_new_signal(sd_bus *bus, const char *path, const char *interface, const char *member, sd_bus_message **m);
112 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);
113 int sd_bus_message_new_method_return(sd_bus *bus, sd_bus_message *call, sd_bus_message **m);
114 int sd_bus_message_new_method_error(sd_bus *bus, sd_bus_message *call, const sd_bus_error *e, sd_bus_message **m);
115
116 sd_bus_message* sd_bus_message_ref(sd_bus_message *m);
117 sd_bus_message* sd_bus_message_unref(sd_bus_message *m);
118
119 int sd_bus_message_get_type(sd_bus_message *m, uint8_t *type);
120 int sd_bus_message_get_serial(sd_bus_message *m, uint64_t *serial);
121 int sd_bus_message_get_reply_serial(sd_bus_message *m, uint64_t *serial);
122 int sd_bus_message_get_no_reply(sd_bus_message *m);
123
124 const char *sd_bus_message_get_path(sd_bus_message *m);
125 const char *sd_bus_message_get_interface(sd_bus_message *m);
126 const char *sd_bus_message_get_member(sd_bus_message *m);
127 const char *sd_bus_message_get_destination(sd_bus_message *m);
128 const char *sd_bus_message_get_sender(sd_bus_message *m);
129 const sd_bus_error *sd_bus_message_get_error(sd_bus_message *m);
130
131 int sd_bus_message_get_monotonic_timestamp(sd_bus_message *m, uint64_t *usec);
132 int sd_bus_message_get_realtime_timestamp(sd_bus_message *m, uint64_t *usec);
133 int sd_bus_message_get_uid(sd_bus_message *m, uid_t *uid);
134 int sd_bus_message_get_gid(sd_bus_message *m, gid_t *gid);
135 int sd_bus_message_get_pid(sd_bus_message *m, pid_t *pid);
136 int sd_bus_message_get_tid(sd_bus_message *m, pid_t *tid);
137 int sd_bus_message_get_pid_starttime(sd_bus_message *m, uint64_t *usec);
138 int sd_bus_message_get_selinux_context(sd_bus_message *m, const char **r);
139 int sd_bus_message_get_comm(sd_bus_message *m, const char **r);
140 int sd_bus_message_get_tid_comm(sd_bus_message *m, const char **r);
141 int sd_bus_message_get_exe(sd_bus_message *m, const char **r);
142 int sd_bus_message_get_cgroup(sd_bus_message *m, const char **r);
143 int sd_bus_message_get_cmdline(sd_bus_message *m, char ***cmdline);
144 int sd_bus_message_get_unit(sd_bus_message *m, const char **unit);
145 int sd_bus_message_get_user_unit(sd_bus_message *m, const char **unit);
146 int sd_bus_message_get_session(sd_bus_message *m, const char **session);
147 int sd_bus_message_get_owner_uid(sd_bus_message *m, uid_t *uid);
148 int sd_bus_message_get_audit_sessionid(sd_bus_message *m, uint32_t *sessionid);
149 int sd_bus_message_get_audit_loginuid(sd_bus_message *m, uid_t *loginuid);
150 int sd_bus_message_has_effective_cap(sd_bus_message *m, int capability);
151
152 int sd_bus_message_is_signal(sd_bus_message *m, const char *interface, const char *member);
153 int sd_bus_message_is_method_call(sd_bus_message *m, const char *interface, const char *member);
154 int sd_bus_message_is_method_error(sd_bus_message *m, const char *name);
155
156 int sd_bus_message_set_no_reply(sd_bus_message *m, int b);
157 int sd_bus_message_set_destination(sd_bus_message *m, const char *destination);
158
159 int sd_bus_message_append(sd_bus_message *m, const char *types, ...);
160 int sd_bus_message_append_basic(sd_bus_message *m, char type, const void *p);
161 int sd_bus_message_open_container(sd_bus_message *m, char type, const char *contents);
162 int sd_bus_message_close_container(sd_bus_message *m);
163
164 int sd_bus_message_read(sd_bus_message *m, const char *types, ...);
165 int sd_bus_message_read_basic(sd_bus_message *m, char type, void *p);
166 int sd_bus_message_enter_container(sd_bus_message *m, char type, const char *contents);
167 int sd_bus_message_exit_container(sd_bus_message *m);
168 int sd_bus_message_peek_type(sd_bus_message *m, char *type, const char **contents);
169 int sd_bus_message_rewind(sd_bus_message *m, int complete);
170
171 int sd_bus_message_append_array(sd_bus_message *m, char type, const void *ptr, size_t size);
172 int sd_bus_message_append_array_ptr(sd_bus_message *m, char type, size_t size, void **ptr);
173
174 int sd_bus_message_read_array(sd_bus_message *m, char type, const void **ptr, size_t *size);
175
176 /* Convenience calls */
177
178 int sd_bus_emit_signal(sd_bus *bus, const char *path, const char *interface, const char *member, const char *types, ...);
179 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, ...);
180 int sd_bus_reply_method_return(sd_bus *bus, sd_bus_message *call, const char *types, ...);
181 int sd_bus_reply_method_error(sd_bus *bus, sd_bus_message *call, const sd_bus_error *e);
182
183 /* Bus management */
184
185 int sd_bus_get_unique_name(sd_bus *bus, const char **unique);
186 int sd_bus_request_name(sd_bus *bus, const char *name, int flags);
187 int sd_bus_release_name(sd_bus *bus, const char *name);
188 int sd_bus_list_names(sd_bus *bus, char ***l);
189 int sd_bus_get_owner(sd_bus *bus, const char *name, char **owner);
190 int sd_bus_get_owner_uid(sd_bus *bus, const char *name, uid_t *uid);
191 int sd_bus_get_owner_pid(sd_bus *bus, const char *name, pid_t *pid);
192 int sd_bus_get_owner_machine_id(sd_bus *bus, const char *name, sd_id128_t *machine);
193
194 /* Error structures */
195
196 #define SD_BUS_ERROR_NULL ((sd_bus_error) {NULL, NULL, 0})
197 #define SD_BUS_ERROR_MAKE(name, message) ((sd_bus_error) {(name), (message), 0})
198
199 void sd_bus_error_free(sd_bus_error *e);
200 int sd_bus_error_set(sd_bus_error *e, const char *name, const char *format, ...)  _sd_printf_attr_(3, 0);
201 void sd_bus_error_set_const(sd_bus_error *e, const char *name, const char *message);
202 int sd_bus_error_copy(sd_bus_error *dest, const sd_bus_error *e);
203 int sd_bus_error_is_set(const sd_bus_error *e);
204 int sd_bus_error_has_name(const sd_bus_error *e, const char *name);
205
206 #ifdef __cplusplus
207 }
208 #endif
209
210 #endif