Implement afb_req_has_permission
[src/app-framework-binder.git] / src / afb-hook.h
1 /*
2  * Copyright (C) 2016, 2017 "IoT.bzh"
3  * Author José Bollo <jose.bollo@iot.bzh>
4  *
5  * Licensed under the Apache License, Version 2.0 (the "License");
6  * you may not use this file except in compliance with the License.
7  * You may obtain a copy of the License at
8  *
9  *   http://www.apache.org/licenses/LICENSE-2.0
10  *
11  * Unless required by applicable law or agreed to in writing, software
12  * distributed under the License is distributed on an "AS IS" BASIS,
13  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14  * See the License for the specific language governing permissions and
15  * limitations under the License.
16  */
17
18 #pragma once
19
20 #include <stdarg.h>
21 #include <time.h>
22
23 struct req;
24 struct afb_context;
25 struct json_object;
26 struct afb_arg;
27 struct afb_event;
28 struct afb_session;
29 struct afb_xreq;
30 struct afb_ditf;
31 struct afb_svc;
32 struct afb_stored_req;
33 struct sd_bus;
34 struct sd_event;
35 struct afb_hook_xreq;
36 struct afb_hook_ditf;
37 struct afb_hook_svc;
38 struct afb_hook_evt;
39 struct afb_hook_global;
40
41 /*********************************************************
42 * section hookid
43 *********************************************************/
44 struct afb_hookid
45 {
46         unsigned id;            /* id of the hook event */
47         struct timespec time;   /* time of the hook event */
48 };
49
50 /*********************************************************
51 * section hooking xreq
52 *********************************************************/
53
54 /* individual flags */
55 #define afb_hook_flag_req_begin                 0x00000001
56 #define afb_hook_flag_req_end                   0x00000002
57 #define afb_hook_flag_req_json                  0x00000004
58 #define afb_hook_flag_req_get                   0x00000008
59 #define afb_hook_flag_req_success               0x00000010
60 #define afb_hook_flag_req_fail                  0x00000020
61 #define afb_hook_flag_req_context_get           0x00000040
62 #define afb_hook_flag_req_context_set           0x00000080
63 #define afb_hook_flag_req_addref                0x00000100
64 #define afb_hook_flag_req_unref                 0x00000200
65 #define afb_hook_flag_req_session_close         0x00000400
66 #define afb_hook_flag_req_session_set_LOA       0x00000800
67 #define afb_hook_flag_req_subscribe             0x00001000
68 #define afb_hook_flag_req_unsubscribe           0x00002000
69 #define afb_hook_flag_req_subcall               0x00004000
70 #define afb_hook_flag_req_subcall_result        0x00008000
71 #define afb_hook_flag_req_subcallsync           0x00010000
72 #define afb_hook_flag_req_subcallsync_result    0x00020000
73 #define afb_hook_flag_req_vverbose              0x00040000
74 #define afb_hook_flag_req_store                 0x00080000
75 #define afb_hook_flag_req_unstore               0x00100000
76 #define afb_hook_flag_req_subcall_req           0x00200000
77 #define afb_hook_flag_req_subcall_req_result    0x00400000
78 #define afb_hook_flag_req_has_permission        0x00800000
79
80 /* common flags */
81 #define afb_hook_flags_req_life         (afb_hook_flag_req_begin|afb_hook_flag_req_end)
82 #define afb_hook_flags_req_args         (afb_hook_flag_req_json|afb_hook_flag_req_get)
83 #define afb_hook_flags_req_result       (afb_hook_flag_req_success|afb_hook_flag_req_fail)
84 #define afb_hook_flags_req_session      (afb_hook_flag_req_session_close|afb_hook_flag_req_session_set_LOA)
85 #define afb_hook_flags_req_event        (afb_hook_flag_req_subscribe|afb_hook_flag_req_unsubscribe)
86 #define afb_hook_flags_req_subcalls     (afb_hook_flag_req_subcall|afb_hook_flag_req_subcall_result\
87                                         |afb_hook_flag_req_subcall_req|afb_hook_flag_req_subcall_req_result\
88                                         |afb_hook_flag_req_subcallsync|afb_hook_flag_req_subcallsync_result)
89
90 /* extra flags */
91 #define afb_hook_flags_req_ref          (afb_hook_flag_req_addref|afb_hook_flag_req_unref)
92 #define afb_hook_flags_req_context      (afb_hook_flag_req_context_get|afb_hook_flag_req_context_set)
93 #define afb_hook_flags_req_stores       (afb_hook_flag_req_store|afb_hook_flag_req_unstore)
94
95 /* predefined groups */
96 #define afb_hook_flags_req_common       (afb_hook_flags_req_life|afb_hook_flags_req_args|afb_hook_flags_req_result\
97                                         |afb_hook_flags_req_session|afb_hook_flags_req_event|afb_hook_flags_req_subcalls\
98                                         |afb_hook_flag_req_vverbose|afb_hook_flag_req_has_permission)
99 #define afb_hook_flags_req_extra        (afb_hook_flags_req_common|afb_hook_flags_req_ref|afb_hook_flags_req_context\
100                                         |afb_hook_flags_req_stores)
101 #define afb_hook_flags_req_all          (afb_hook_flags_req_extra)
102
103 struct afb_hook_xreq_itf {
104         void (*hook_xreq_begin)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq);
105         void (*hook_xreq_end)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq);
106         void (*hook_xreq_json)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq, struct json_object *obj);
107         void (*hook_xreq_get)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq, const char *name, struct afb_arg arg);
108         void (*hook_xreq_success)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq, struct json_object *obj, const char *info);
109         void (*hook_xreq_fail)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq, const char *status, const char *info);
110         void (*hook_xreq_context_get)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq, void *value);
111         void (*hook_xreq_context_set)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq, void *value, void (*free_value)(void*));
112         void (*hook_xreq_addref)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq);
113         void (*hook_xreq_unref)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq);
114         void (*hook_xreq_session_close)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq);
115         void (*hook_xreq_session_set_LOA)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq, unsigned level, int result);
116         void (*hook_xreq_subscribe)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq, struct afb_event event, int result);
117         void (*hook_xreq_unsubscribe)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq, struct afb_event event, int result);
118         void (*hook_xreq_subcall)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq, const char *api, const char *verb, struct json_object *args);
119         void (*hook_xreq_subcall_result)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq, int status, struct json_object *result);
120         void (*hook_xreq_subcallsync)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq, const char *api, const char *verb, struct json_object *args);
121         void (*hook_xreq_subcallsync_result)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq, int status, struct json_object *result);
122         void (*hook_xreq_vverbose)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq, int level, const char *file, int line, const char *func, const char *fmt, va_list args);
123         void (*hook_xreq_store)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq, struct afb_stored_req *sreq);
124         void (*hook_xreq_unstore)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq);
125         void (*hook_xreq_subcall_req)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq, const char *api, const char *verb, struct json_object *args);
126         void (*hook_xreq_subcall_req_result)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq, int status, struct json_object *result);
127         void (*hook_xreq_has_permission)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq, const char *permission, int result);
128 };
129
130 extern void afb_hook_init_xreq(struct afb_xreq *xreq);
131
132 extern struct afb_hook_xreq *afb_hook_create_xreq(const char *api, const char *verb, struct afb_session *session, int flags, struct afb_hook_xreq_itf *itf, void *closure);
133 extern struct afb_hook_xreq *afb_hook_addref_xreq(struct afb_hook_xreq *spec);
134 extern void afb_hook_unref_xreq(struct afb_hook_xreq *spec);
135
136 /* hooks for xreq */
137 extern void afb_hook_xreq_begin(const struct afb_xreq *xreq);
138 extern void afb_hook_xreq_end(const struct afb_xreq *xreq);
139 extern struct json_object *afb_hook_xreq_json(const struct afb_xreq *xreq, struct json_object *obj);
140 extern struct afb_arg afb_hook_xreq_get(const struct afb_xreq *xreq, const char *name, struct afb_arg arg);
141 extern void afb_hook_xreq_success(const struct afb_xreq *xreq, struct json_object *obj, const char *info);
142 extern void afb_hook_xreq_fail(const struct afb_xreq *xreq, const char *status, const char *info);
143 extern void *afb_hook_xreq_context_get(const struct afb_xreq *xreq, void *value);
144 extern void afb_hook_xreq_context_set(const struct afb_xreq *xreq, void *value, void (*free_value)(void*));
145 extern void afb_hook_xreq_addref(const struct afb_xreq *xreq);
146 extern void afb_hook_xreq_unref(const struct afb_xreq *xreq);
147 extern void afb_hook_xreq_session_close(const struct afb_xreq *xreq);
148 extern int afb_hook_xreq_session_set_LOA(const struct afb_xreq *xreq, unsigned level, int result);
149 extern int afb_hook_xreq_subscribe(const struct afb_xreq *xreq, struct afb_event event, int result);
150 extern int afb_hook_xreq_unsubscribe(const struct afb_xreq *xreq, struct afb_event event, int result);
151 extern void afb_hook_xreq_subcall(const struct afb_xreq *xreq, const char *api, const char *verb, struct json_object *args);
152 extern void afb_hook_xreq_subcall_result(const struct afb_xreq *xreq, int status, struct json_object *result);
153 extern void afb_hook_xreq_subcallsync(const struct afb_xreq *xreq, const char *api, const char *verb, struct json_object *args);
154 extern int afb_hook_xreq_subcallsync_result(const struct afb_xreq *xreq, int status, struct json_object *result);
155 extern void afb_hook_xreq_vverbose(const struct afb_xreq *xreq, int level, const char *file, int line, const char *func, const char *fmt, va_list args);
156 extern void afb_hook_xreq_store(const struct afb_xreq *xreq, struct afb_stored_req *sreq);
157 extern void afb_hook_xreq_unstore(const struct afb_xreq *xreq);
158 extern void afb_hook_xreq_subcall_req(const struct afb_xreq *xreq, const char *api, const char *verb, struct json_object *args);
159 extern void afb_hook_xreq_subcall_req_result(const struct afb_xreq *xreq, int status, struct json_object *result);
160 extern int afb_hook_xreq_has_permission(const struct afb_xreq *xreq, const char *permission, int result);
161
162 /*********************************************************
163 * section hooking ditf (daemon interface)
164 *********************************************************/
165
166 #define afb_hook_flag_ditf_vverbose                     0x000001
167 #define afb_hook_flag_ditf_event_make                   0x000002
168 #define afb_hook_flag_ditf_event_broadcast_before       0x000004
169 #define afb_hook_flag_ditf_event_broadcast_after        0x000008
170 #define afb_hook_flag_ditf_get_event_loop               0x000010
171 #define afb_hook_flag_ditf_get_user_bus                 0x000020
172 #define afb_hook_flag_ditf_get_system_bus               0x000040
173 #define afb_hook_flag_ditf_rootdir_get_fd               0x000080
174 #define afb_hook_flag_ditf_rootdir_open_locale          0x000100
175 #define afb_hook_flag_ditf_queue_job                    0x000200
176 #define afb_hook_flag_ditf_unstore_req                  0x000400
177 #define afb_hook_flag_ditf_require_api                  0x000800
178 #define afb_hook_flag_ditf_require_api_result           0x001000
179
180 #define afb_hook_flags_ditf_common      (afb_hook_flag_ditf_vverbose\
181                                         |afb_hook_flag_ditf_event_make\
182                                         |afb_hook_flag_ditf_event_broadcast_before\
183                                         |afb_hook_flag_ditf_event_broadcast_after)
184 #define afb_hook_flags_ditf_extra       (afb_hook_flag_ditf_get_event_loop\
185                                         |afb_hook_flag_ditf_get_user_bus\
186                                         |afb_hook_flag_ditf_get_system_bus\
187                                         |afb_hook_flag_ditf_rootdir_get_fd\
188                                         |afb_hook_flag_ditf_rootdir_open_locale\
189                                         |afb_hook_flag_ditf_queue_job\
190                                         |afb_hook_flag_ditf_unstore_req\
191                                         |afb_hook_flag_ditf_require_api\
192                                         |afb_hook_flag_ditf_require_api_result)
193
194 #define afb_hook_flags_ditf_all         (afb_hook_flags_ditf_common|afb_hook_flags_ditf_extra)
195
196 struct afb_hook_ditf_itf {
197         void (*hook_ditf_event_broadcast_before)(void *closure, const struct afb_hookid *hookid, const struct afb_ditf *ditf, const char *name, struct json_object *object);
198         void (*hook_ditf_event_broadcast_after)(void *closure, const struct afb_hookid *hookid, const struct afb_ditf *ditf, const char *name, struct json_object *object, int result);
199         void (*hook_ditf_get_event_loop)(void *closure, const struct afb_hookid *hookid, const struct afb_ditf *ditf, struct sd_event *result);
200         void (*hook_ditf_get_user_bus)(void *closure, const struct afb_hookid *hookid, const struct afb_ditf *ditf, struct sd_bus *result);
201         void (*hook_ditf_get_system_bus)(void *closure, const struct afb_hookid *hookid, const struct afb_ditf *ditf, struct sd_bus *result);
202         void (*hook_ditf_vverbose)(void *closure, const struct afb_hookid *hookid, const struct afb_ditf *ditf, int level, const char *file, int line, const char *function, const char *fmt, va_list args);
203         void (*hook_ditf_event_make)(void *closure, const struct afb_hookid *hookid, const struct afb_ditf *ditf, const char *name, struct afb_event result);
204         void (*hook_ditf_rootdir_get_fd)(void *closure, const struct afb_hookid *hookid, const struct afb_ditf *ditf, int result);
205         void (*hook_ditf_rootdir_open_locale)(void *closure, const struct afb_hookid *hookid, const struct afb_ditf *ditf, const char *filename, int flags, const char *locale, int result);
206         void (*hook_ditf_queue_job)(void *closure, const struct afb_hookid *hookid, const struct afb_ditf *ditf, void (*callback)(int signum, void *arg), void *argument, void *group, int timeout, int result);
207         void (*hook_ditf_unstore_req)(void *closure, const struct afb_hookid *hookid, const struct afb_ditf *ditf, struct afb_stored_req *sreq);
208         void (*hook_ditf_require_api)(void *closure, const struct afb_hookid *hookid, const struct afb_ditf *ditf, const char *name, int initialized);
209         void (*hook_ditf_require_api_result)(void *closure, const struct afb_hookid *hookid, const struct afb_ditf *ditf, const char *name, int initialized, int result);
210 };
211
212 extern void afb_hook_ditf_event_broadcast_before(const struct afb_ditf *ditf, const char *name, struct json_object *object);
213 extern int afb_hook_ditf_event_broadcast_after(const struct afb_ditf *ditf, const char *name, struct json_object *object, int result);
214 extern struct sd_event *afb_hook_ditf_get_event_loop(const struct afb_ditf *ditf, struct sd_event *result);
215 extern struct sd_bus *afb_hook_ditf_get_user_bus(const struct afb_ditf *ditf, struct sd_bus *result);
216 extern struct sd_bus *afb_hook_ditf_get_system_bus(const struct afb_ditf *ditf, struct sd_bus *result);
217 extern void afb_hook_ditf_vverbose(const struct afb_ditf *ditf, int level, const char *file, int line, const char *function, const char *fmt, va_list args);
218 extern struct afb_event afb_hook_ditf_event_make(const struct afb_ditf *ditf, const char *name, struct afb_event result);
219 extern int afb_hook_ditf_rootdir_get_fd(const struct afb_ditf *ditf, int result);
220 extern int afb_hook_ditf_rootdir_open_locale(const struct afb_ditf *ditf, const char *filename, int flags, const char *locale, int result);
221 extern int afb_hook_ditf_queue_job(const struct afb_ditf *ditf, void (*callback)(int signum, void *arg), void *argument, void *group, int timeout, int result);
222 extern void afb_hook_ditf_unstore_req(const struct afb_ditf *ditf, struct afb_stored_req *sreq);
223 extern void afb_hook_ditf_require_api(const struct afb_ditf *ditf, const char *name, int initialized);
224 extern int afb_hook_ditf_require_api_result(const struct afb_ditf *ditf, const char *name, int initialized, int result);
225
226 extern int afb_hook_flags_ditf(const char *api);
227 extern struct afb_hook_ditf *afb_hook_create_ditf(const char *api, int flags, struct afb_hook_ditf_itf *itf, void *closure);
228 extern struct afb_hook_ditf *afb_hook_addref_ditf(struct afb_hook_ditf *hook);
229 extern void afb_hook_unref_ditf(struct afb_hook_ditf *hook);
230
231 /*********************************************************
232 * section hooking svc (service interface)
233 *********************************************************/
234
235 #define afb_hook_flag_svc_start_before                  0x000001
236 #define afb_hook_flag_svc_start_after                   0x000002
237 #define afb_hook_flag_svc_on_event_before               0x000004
238 #define afb_hook_flag_svc_on_event_after                0x000008
239 #define afb_hook_flag_svc_call                          0x000010
240 #define afb_hook_flag_svc_call_result                   0x000020
241 #define afb_hook_flag_svc_callsync                      0x000040
242 #define afb_hook_flag_svc_callsync_result               0x000080
243
244 #define afb_hook_flags_svc_all          (afb_hook_flag_svc_start_before|afb_hook_flag_svc_start_after\
245                                         |afb_hook_flag_svc_on_event_before|afb_hook_flag_svc_on_event_after\
246                                         |afb_hook_flag_svc_call|afb_hook_flag_svc_call_result\
247                                         |afb_hook_flag_svc_callsync|afb_hook_flag_svc_callsync_result)
248
249 struct afb_hook_svc_itf {
250         void (*hook_svc_start_before)(void *closure, const struct afb_hookid *hookid, const struct afb_svc *svc);
251         void (*hook_svc_start_after)(void *closure, const struct afb_hookid *hookid, const struct afb_svc *svc, int status);
252         void (*hook_svc_on_event_before)(void *closure, const struct afb_hookid *hookid, const struct afb_svc *svc, const char *event, int eventid, struct json_object *object);
253         void (*hook_svc_on_event_after)(void *closure, const struct afb_hookid *hookid, const struct afb_svc *svc, const char *event, int eventid, struct json_object *object);
254         void (*hook_svc_call)(void *closure, const struct afb_hookid *hookid, const struct afb_svc *svc, const char *api, const char *verb, struct json_object *args);
255         void (*hook_svc_call_result)(void *closure, const struct afb_hookid *hookid, const struct afb_svc *svc, int status, struct json_object *result);
256         void (*hook_svc_callsync)(void *closure, const struct afb_hookid *hookid, const struct afb_svc *svc, const char *api, const char *verb, struct json_object *args);
257         void (*hook_svc_callsync_result)(void *closure, const struct afb_hookid *hookid, const struct afb_svc *svc, int status, struct json_object *result);
258 };
259
260 extern void afb_hook_svc_start_before(const struct afb_svc *svc);
261 extern int afb_hook_svc_start_after(const struct afb_svc *svc, int status);
262 extern void afb_hook_svc_on_event_before(const struct afb_svc *svc, const char *event, int eventid, struct json_object *object);
263 extern void afb_hook_svc_on_event_after(const struct afb_svc *svc, const char *event, int eventid, struct json_object *object);
264 extern void afb_hook_svc_call(const struct afb_svc *svc, const char *api, const char *verb, struct json_object *args);
265 extern void afb_hook_svc_call_result(const struct afb_svc *svc, int status, struct json_object *result);
266 extern void afb_hook_svc_callsync(const struct afb_svc *svc, const char *api, const char *verb, struct json_object *args);
267 extern int afb_hook_svc_callsync_result(const struct afb_svc *svc, int status, struct json_object *result);
268
269 extern int afb_hook_flags_svc(const char *api);
270 extern struct afb_hook_svc *afb_hook_create_svc(const char *api, int flags, struct afb_hook_svc_itf *itf, void *closure);
271 extern struct afb_hook_svc *afb_hook_addref_svc(struct afb_hook_svc *hook);
272 extern void afb_hook_unref_svc(struct afb_hook_svc *hook);
273
274 /*********************************************************
275 * section hooking evt (event interface)
276 *********************************************************/
277
278 #define afb_hook_flag_evt_create                        0x000001
279 #define afb_hook_flag_evt_push_before                   0x000002
280 #define afb_hook_flag_evt_push_after                    0x000004
281 #define afb_hook_flag_evt_broadcast_before              0x000008
282 #define afb_hook_flag_evt_broadcast_after               0x000010
283 #define afb_hook_flag_evt_name                          0x000020
284 #define afb_hook_flag_evt_drop                          0x000040
285
286 #define afb_hook_flags_evt_common       (afb_hook_flag_evt_push_before|afb_hook_flag_evt_broadcast_before)
287 #define afb_hook_flags_evt_extra        (afb_hook_flags_evt_common\
288                                         |afb_hook_flag_evt_push_after|afb_hook_flag_evt_broadcast_after\
289                                         |afb_hook_flag_evt_create|afb_hook_flag_evt_drop)
290 #define afb_hook_flags_evt_all          (afb_hook_flags_evt_extra|afb_hook_flag_evt_name)
291
292 struct afb_hook_evt_itf {
293         void (*hook_evt_create)(void *closure, const struct afb_hookid *hookid, const char *evt, int id);
294         void (*hook_evt_push_before)(void *closure, const struct afb_hookid *hookid, const char *evt, int id, struct json_object *obj);
295         void (*hook_evt_push_after)(void *closure, const struct afb_hookid *hookid, const char *evt, int id, struct json_object *obj, int result);
296         void (*hook_evt_broadcast_before)(void *closure, const struct afb_hookid *hookid, const char *evt, int id, struct json_object *obj);
297         void (*hook_evt_broadcast_after)(void *closure, const struct afb_hookid *hookid, const char *evt, int id, struct json_object *obj, int result);
298         void (*hook_evt_name)(void *closure, const struct afb_hookid *hookid, const char *evt, int id);
299         void (*hook_evt_drop)(void *closure, const struct afb_hookid *hookid, const char *evt, int id);
300 };
301
302 extern void afb_hook_evt_create(const char *evt, int id);
303 extern void afb_hook_evt_push_before(const char *evt, int id, struct json_object *obj);
304 extern int afb_hook_evt_push_after(const char *evt, int id, struct json_object *obj, int result);
305 extern void afb_hook_evt_broadcast_before(const char *evt, int id, struct json_object *obj);
306 extern int afb_hook_evt_broadcast_after(const char *evt, int id, struct json_object *obj, int result);
307 extern void afb_hook_evt_name(const char *evt, int id);
308 extern void afb_hook_evt_drop(const char *evt, int id);
309
310 extern int afb_hook_flags_evt(const char *name);
311 extern struct afb_hook_evt *afb_hook_create_evt(const char *pattern, int flags, struct afb_hook_evt_itf *itf, void *closure);
312 extern struct afb_hook_evt *afb_hook_addref_evt(struct afb_hook_evt *hook);
313 extern void afb_hook_unref_evt(struct afb_hook_evt *hook);
314
315 /*********************************************************
316 * section hooking global (global interface)
317 *********************************************************/
318
319 #define afb_hook_flag_global_vverbose                   0x000001
320
321 #define afb_hook_flags_global_all       (afb_hook_flag_global_vverbose)
322
323 struct afb_hook_global_itf {
324         void (*hook_global_vverbose)(void *closure, const struct afb_hookid *hookid, int level, const char *file, int line, const char *function, const char *fmt, va_list args);
325 };
326
327 extern struct afb_hook_global *afb_hook_create_global(int flags, struct afb_hook_global_itf *itf, void *closure);
328 extern struct afb_hook_global *afb_hook_addref_global(struct afb_hook_global *hook);
329 extern void afb_hook_unref_global(struct afb_hook_global *hook);
330