2 * Copyright (C) 2016, 2017 "IoT.bzh"
3 * Author José Bollo <jose.bollo@iot.bzh>
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
9 * http://www.apache.org/licenses/LICENSE-2.0
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.
31 struct afb_stored_req;
38 struct afb_hook_global;
40 /*********************************************************
42 *********************************************************/
45 unsigned id; /* id of the hook event */
46 struct timespec time; /* time of the hook event */
49 /*********************************************************
50 * section hooking xreq
51 *********************************************************/
53 /* individual flags */
54 #define afb_hook_flag_req_begin 0x00000001
55 #define afb_hook_flag_req_end 0x00000002
56 #define afb_hook_flag_req_json 0x00000004
57 #define afb_hook_flag_req_get 0x00000008
58 #define afb_hook_flag_req_success 0x00000010
59 #define afb_hook_flag_req_fail 0x00000020
60 #define afb_hook_flag_req_context_get 0x00000040
61 #define afb_hook_flag_req_context_set 0x00000080
62 #define afb_hook_flag_req_addref 0x00000100
63 #define afb_hook_flag_req_unref 0x00000200
64 #define afb_hook_flag_req_session_close 0x00000400
65 #define afb_hook_flag_req_session_set_LOA 0x00000800
66 #define afb_hook_flag_req_subscribe 0x00001000
67 #define afb_hook_flag_req_unsubscribe 0x00002000
68 #define afb_hook_flag_req_subcall 0x00004000
69 #define afb_hook_flag_req_subcall_result 0x00008000
70 #define afb_hook_flag_req_subcallsync 0x00010000
71 #define afb_hook_flag_req_subcallsync_result 0x00020000
72 #define afb_hook_flag_req_vverbose 0x00040000
73 #define afb_hook_flag_req_store 0x00080000
74 #define afb_hook_flag_req_unstore 0x00100000
75 #define afb_hook_flag_req_subcall_req 0x00200000
76 #define afb_hook_flag_req_subcall_req_result 0x00400000
77 #define afb_hook_flag_req_has_permission 0x00800000
78 #define afb_hook_flag_req_get_application_id 0x01000000
79 #define afb_hook_flag_req_context_make 0x02000000
82 #define afb_hook_flags_req_life (afb_hook_flag_req_begin|afb_hook_flag_req_end)
83 #define afb_hook_flags_req_args (afb_hook_flag_req_json|afb_hook_flag_req_get)
84 #define afb_hook_flags_req_result (afb_hook_flag_req_success|afb_hook_flag_req_fail)
85 #define afb_hook_flags_req_session (afb_hook_flag_req_session_close|afb_hook_flag_req_session_set_LOA)
86 #define afb_hook_flags_req_event (afb_hook_flag_req_subscribe|afb_hook_flag_req_unsubscribe)
87 #define afb_hook_flags_req_subcalls (afb_hook_flag_req_subcall|afb_hook_flag_req_subcall_result\
88 |afb_hook_flag_req_subcall_req|afb_hook_flag_req_subcall_req_result\
89 |afb_hook_flag_req_subcallsync|afb_hook_flag_req_subcallsync_result)
90 #define afb_hook_flags_req_security (afb_hook_flag_req_has_permission|afb_hook_flag_req_get_application_id)
93 #define afb_hook_flags_req_ref (afb_hook_flag_req_addref|afb_hook_flag_req_unref)
94 #define afb_hook_flags_req_context (afb_hook_flag_req_context_get|afb_hook_flag_req_context_set\
95 |afb_hook_flag_req_context_make)
96 #define afb_hook_flags_req_stores (afb_hook_flag_req_store|afb_hook_flag_req_unstore)
98 /* predefined groups */
99 #define afb_hook_flags_req_common (afb_hook_flags_req_life|afb_hook_flags_req_args|afb_hook_flags_req_result\
100 |afb_hook_flags_req_session|afb_hook_flags_req_event|afb_hook_flags_req_subcalls\
101 |afb_hook_flag_req_vverbose|afb_hook_flags_req_security)
102 #define afb_hook_flags_req_extra (afb_hook_flags_req_common|afb_hook_flags_req_ref|afb_hook_flags_req_context\
103 |afb_hook_flags_req_stores)
104 #define afb_hook_flags_req_all (afb_hook_flags_req_extra)
106 struct afb_hook_xreq_itf {
107 void (*hook_xreq_begin)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq);
108 void (*hook_xreq_end)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq);
109 void (*hook_xreq_json)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq, struct json_object *obj);
110 void (*hook_xreq_get)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq, const char *name, struct afb_arg arg);
111 void (*hook_xreq_success)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq, struct json_object *obj, const char *info);
112 void (*hook_xreq_fail)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq, const char *status, const char *info);
113 void (*hook_xreq_context_get)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq, void *value);
114 void (*hook_xreq_context_set)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq, void *value, void (*free_value)(void*));
115 void (*hook_xreq_addref)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq);
116 void (*hook_xreq_unref)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq);
117 void (*hook_xreq_session_close)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq);
118 void (*hook_xreq_session_set_LOA)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq, unsigned level, int result);
119 void (*hook_xreq_subscribe)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq, struct afb_event event, int result);
120 void (*hook_xreq_unsubscribe)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq, struct afb_event event, int result);
121 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);
122 void (*hook_xreq_subcall_result)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq, int status, struct json_object *result);
123 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);
124 void (*hook_xreq_subcallsync_result)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq, int status, struct json_object *result);
125 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);
126 void (*hook_xreq_store)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq, struct afb_stored_req *sreq);
127 void (*hook_xreq_unstore)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq);
128 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);
129 void (*hook_xreq_subcall_req_result)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq, int status, struct json_object *result);
130 void (*hook_xreq_has_permission)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq, const char *permission, int result);
131 void (*hook_xreq_get_application_id)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq, char *result);
132 void (*hook_xreq_context_make)(void *closure, const struct afb_hookid *hookid, const struct afb_xreq *xreq, int replace, void *(*create_value)(void*), void (*free_value)(void*), void *create_closure, void *result);
135 extern void afb_hook_init_xreq(struct afb_xreq *xreq);
137 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);
138 extern struct afb_hook_xreq *afb_hook_addref_xreq(struct afb_hook_xreq *spec);
139 extern void afb_hook_unref_xreq(struct afb_hook_xreq *spec);
142 extern void afb_hook_xreq_begin(const struct afb_xreq *xreq);
143 extern void afb_hook_xreq_end(const struct afb_xreq *xreq);
144 extern struct json_object *afb_hook_xreq_json(const struct afb_xreq *xreq, struct json_object *obj);
145 extern struct afb_arg afb_hook_xreq_get(const struct afb_xreq *xreq, const char *name, struct afb_arg arg);
146 extern void afb_hook_xreq_success(const struct afb_xreq *xreq, struct json_object *obj, const char *info);
147 extern void afb_hook_xreq_fail(const struct afb_xreq *xreq, const char *status, const char *info);
148 extern void *afb_hook_xreq_context_get(const struct afb_xreq *xreq, void *value);
149 extern void afb_hook_xreq_context_set(const struct afb_xreq *xreq, void *value, void (*free_value)(void*));
150 extern void afb_hook_xreq_addref(const struct afb_xreq *xreq);
151 extern void afb_hook_xreq_unref(const struct afb_xreq *xreq);
152 extern void afb_hook_xreq_session_close(const struct afb_xreq *xreq);
153 extern int afb_hook_xreq_session_set_LOA(const struct afb_xreq *xreq, unsigned level, int result);
154 extern int afb_hook_xreq_subscribe(const struct afb_xreq *xreq, struct afb_event event, int result);
155 extern int afb_hook_xreq_unsubscribe(const struct afb_xreq *xreq, struct afb_event event, int result);
156 extern void afb_hook_xreq_subcall(const struct afb_xreq *xreq, const char *api, const char *verb, struct json_object *args);
157 extern void afb_hook_xreq_subcall_result(const struct afb_xreq *xreq, int status, struct json_object *result);
158 extern void afb_hook_xreq_subcallsync(const struct afb_xreq *xreq, const char *api, const char *verb, struct json_object *args);
159 extern int afb_hook_xreq_subcallsync_result(const struct afb_xreq *xreq, int status, struct json_object *result);
160 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);
161 extern void afb_hook_xreq_store(const struct afb_xreq *xreq, struct afb_stored_req *sreq);
162 extern void afb_hook_xreq_unstore(const struct afb_xreq *xreq);
163 extern void afb_hook_xreq_subcall_req(const struct afb_xreq *xreq, const char *api, const char *verb, struct json_object *args);
164 extern void afb_hook_xreq_subcall_req_result(const struct afb_xreq *xreq, int status, struct json_object *result);
165 extern int afb_hook_xreq_has_permission(const struct afb_xreq *xreq, const char *permission, int result);
166 extern char *afb_hook_xreq_get_application_id(const struct afb_xreq *xreq, char *result);
167 extern void *afb_hook_xreq_context_make(const struct afb_xreq *xreq, int replace, void *(*create_value)(void*), void (*free_value)(void*), void *create_closure, void *result);
169 /*********************************************************
170 * section hooking export (daemon interface)
171 *********************************************************/
173 #define afb_hook_flag_ditf_vverbose 0x000001
174 #define afb_hook_flag_ditf_event_make 0x000002
175 #define afb_hook_flag_ditf_event_broadcast_before 0x000004
176 #define afb_hook_flag_ditf_event_broadcast_after 0x000008
177 #define afb_hook_flag_ditf_get_event_loop 0x000010
178 #define afb_hook_flag_ditf_get_user_bus 0x000020
179 #define afb_hook_flag_ditf_get_system_bus 0x000040
180 #define afb_hook_flag_ditf_rootdir_get_fd 0x000080
181 #define afb_hook_flag_ditf_rootdir_open_locale 0x000100
182 #define afb_hook_flag_ditf_queue_job 0x000200
183 #define afb_hook_flag_ditf_unstore_req 0x000400
184 #define afb_hook_flag_ditf_require_api 0x000800
185 #define afb_hook_flag_ditf_require_api_result 0x001000
186 #define afb_hook_flag_ditf_rename_api 0x002000
188 #define afb_hook_flags_ditf_common (afb_hook_flag_ditf_vverbose\
189 |afb_hook_flag_ditf_event_make\
190 |afb_hook_flag_ditf_event_broadcast_before\
191 |afb_hook_flag_ditf_event_broadcast_after\
192 |afb_hook_flag_ditf_rename_api)
193 #define afb_hook_flags_ditf_extra (afb_hook_flag_ditf_get_event_loop\
194 |afb_hook_flag_ditf_get_user_bus\
195 |afb_hook_flag_ditf_get_system_bus\
196 |afb_hook_flag_ditf_rootdir_get_fd\
197 |afb_hook_flag_ditf_rootdir_open_locale\
198 |afb_hook_flag_ditf_queue_job\
199 |afb_hook_flag_ditf_unstore_req\
200 |afb_hook_flag_ditf_require_api\
201 |afb_hook_flag_ditf_require_api_result)
203 #define afb_hook_flags_ditf_all (afb_hook_flags_ditf_common|afb_hook_flags_ditf_extra)
205 struct afb_hook_ditf_itf {
206 void (*hook_ditf_event_broadcast_before)(void *closure, const struct afb_hookid *hookid, const struct afb_export *export, const char *name, struct json_object *object);
207 void (*hook_ditf_event_broadcast_after)(void *closure, const struct afb_hookid *hookid, const struct afb_export *export, const char *name, struct json_object *object, int result);
208 void (*hook_ditf_get_event_loop)(void *closure, const struct afb_hookid *hookid, const struct afb_export *export, struct sd_event *result);
209 void (*hook_ditf_get_user_bus)(void *closure, const struct afb_hookid *hookid, const struct afb_export *export, struct sd_bus *result);
210 void (*hook_ditf_get_system_bus)(void *closure, const struct afb_hookid *hookid, const struct afb_export *export, struct sd_bus *result);
211 void (*hook_ditf_vverbose)(void *closure, const struct afb_hookid *hookid, const struct afb_export *export, int level, const char *file, int line, const char *function, const char *fmt, va_list args);
212 void (*hook_ditf_event_make)(void *closure, const struct afb_hookid *hookid, const struct afb_export *export, const char *name, struct afb_event result);
213 void (*hook_ditf_rootdir_get_fd)(void *closure, const struct afb_hookid *hookid, const struct afb_export *export, int result);
214 void (*hook_ditf_rootdir_open_locale)(void *closure, const struct afb_hookid *hookid, const struct afb_export *export, const char *filename, int flags, const char *locale, int result);
215 void (*hook_ditf_queue_job)(void *closure, const struct afb_hookid *hookid, const struct afb_export *export, void (*callback)(int signum, void *arg), void *argument, void *group, int timeout, int result);
216 void (*hook_ditf_unstore_req)(void *closure, const struct afb_hookid *hookid, const struct afb_export *export, struct afb_stored_req *sreq);
217 void (*hook_ditf_require_api)(void *closure, const struct afb_hookid *hookid, const struct afb_export *export, const char *name, int initialized);
218 void (*hook_ditf_require_api_result)(void *closure, const struct afb_hookid *hookid, const struct afb_export *export, const char *name, int initialized, int result);
219 void (*hook_ditf_rename_api)(void *closure, const struct afb_hookid *hookid, const struct afb_export *export, const char *oldname, const char *newname, int result);
222 extern void afb_hook_ditf_event_broadcast_before(const struct afb_export *export, const char *name, struct json_object *object);
223 extern int afb_hook_ditf_event_broadcast_after(const struct afb_export *export, const char *name, struct json_object *object, int result);
224 extern struct sd_event *afb_hook_ditf_get_event_loop(const struct afb_export *export, struct sd_event *result);
225 extern struct sd_bus *afb_hook_ditf_get_user_bus(const struct afb_export *export, struct sd_bus *result);
226 extern struct sd_bus *afb_hook_ditf_get_system_bus(const struct afb_export *export, struct sd_bus *result);
227 extern void afb_hook_ditf_vverbose(const struct afb_export *export, int level, const char *file, int line, const char *function, const char *fmt, va_list args);
228 extern struct afb_event afb_hook_ditf_event_make(const struct afb_export *export, const char *name, struct afb_event result);
229 extern int afb_hook_ditf_rootdir_get_fd(const struct afb_export *export, int result);
230 extern int afb_hook_ditf_rootdir_open_locale(const struct afb_export *export, const char *filename, int flags, const char *locale, int result);
231 extern int afb_hook_ditf_queue_job(const struct afb_export *export, void (*callback)(int signum, void *arg), void *argument, void *group, int timeout, int result);
232 extern void afb_hook_ditf_unstore_req(const struct afb_export *export, struct afb_stored_req *sreq);
233 extern void afb_hook_ditf_require_api(const struct afb_export *export, const char *name, int initialized);
234 extern int afb_hook_ditf_require_api_result(const struct afb_export *export, const char *name, int initialized, int result);
235 extern int afb_hook_ditf_rename_api(const struct afb_export *export, const char *oldname, const char *newname, int result);
237 extern int afb_hook_flags_ditf(const char *api);
238 extern struct afb_hook_ditf *afb_hook_create_ditf(const char *api, int flags, struct afb_hook_ditf_itf *itf, void *closure);
239 extern struct afb_hook_ditf *afb_hook_addref_ditf(struct afb_hook_ditf *hook);
240 extern void afb_hook_unref_ditf(struct afb_hook_ditf *hook);
242 /*********************************************************
243 * section hooking export (service interface)
244 *********************************************************/
246 #define afb_hook_flag_svc_start_before 0x000001
247 #define afb_hook_flag_svc_start_after 0x000002
248 #define afb_hook_flag_svc_on_event_before 0x000004
249 #define afb_hook_flag_svc_on_event_after 0x000008
250 #define afb_hook_flag_svc_call 0x000010
251 #define afb_hook_flag_svc_call_result 0x000020
252 #define afb_hook_flag_svc_callsync 0x000040
253 #define afb_hook_flag_svc_callsync_result 0x000080
255 #define afb_hook_flags_svc_all (afb_hook_flag_svc_start_before|afb_hook_flag_svc_start_after\
256 |afb_hook_flag_svc_on_event_before|afb_hook_flag_svc_on_event_after\
257 |afb_hook_flag_svc_call|afb_hook_flag_svc_call_result\
258 |afb_hook_flag_svc_callsync|afb_hook_flag_svc_callsync_result)
260 struct afb_hook_svc_itf {
261 void (*hook_svc_start_before)(void *closure, const struct afb_hookid *hookid, const struct afb_export *export);
262 void (*hook_svc_start_after)(void *closure, const struct afb_hookid *hookid, const struct afb_export *export, int status);
263 void (*hook_svc_on_event_before)(void *closure, const struct afb_hookid *hookid, const struct afb_export *export, const char *event, int eventid, struct json_object *object);
264 void (*hook_svc_on_event_after)(void *closure, const struct afb_hookid *hookid, const struct afb_export *export, const char *event, int eventid, struct json_object *object);
265 void (*hook_svc_call)(void *closure, const struct afb_hookid *hookid, const struct afb_export *export, const char *api, const char *verb, struct json_object *args);
266 void (*hook_svc_call_result)(void *closure, const struct afb_hookid *hookid, const struct afb_export *export, int status, struct json_object *result);
267 void (*hook_svc_callsync)(void *closure, const struct afb_hookid *hookid, const struct afb_export *export, const char *api, const char *verb, struct json_object *args);
268 void (*hook_svc_callsync_result)(void *closure, const struct afb_hookid *hookid, const struct afb_export *export, int status, struct json_object *result);
271 extern void afb_hook_svc_start_before(const struct afb_export *export);
272 extern int afb_hook_svc_start_after(const struct afb_export *export, int status);
273 extern void afb_hook_svc_on_event_before(const struct afb_export *export, const char *event, int eventid, struct json_object *object);
274 extern void afb_hook_svc_on_event_after(const struct afb_export *export, const char *event, int eventid, struct json_object *object);
275 extern void afb_hook_svc_call(const struct afb_export *export, const char *api, const char *verb, struct json_object *args);
276 extern void afb_hook_svc_call_result(const struct afb_export *export, int status, struct json_object *result);
277 extern void afb_hook_svc_callsync(const struct afb_export *export, const char *api, const char *verb, struct json_object *args);
278 extern int afb_hook_svc_callsync_result(const struct afb_export *export, int status, struct json_object *result);
280 extern int afb_hook_flags_svc(const char *api);
281 extern struct afb_hook_svc *afb_hook_create_svc(const char *api, int flags, struct afb_hook_svc_itf *itf, void *closure);
282 extern struct afb_hook_svc *afb_hook_addref_svc(struct afb_hook_svc *hook);
283 extern void afb_hook_unref_svc(struct afb_hook_svc *hook);
285 /*********************************************************
286 * section hooking evt (event interface)
287 *********************************************************/
289 #define afb_hook_flag_evt_create 0x000001
290 #define afb_hook_flag_evt_push_before 0x000002
291 #define afb_hook_flag_evt_push_after 0x000004
292 #define afb_hook_flag_evt_broadcast_before 0x000008
293 #define afb_hook_flag_evt_broadcast_after 0x000010
294 #define afb_hook_flag_evt_name 0x000020
295 #define afb_hook_flag_evt_drop 0x000040
297 #define afb_hook_flags_evt_common (afb_hook_flag_evt_push_before|afb_hook_flag_evt_broadcast_before)
298 #define afb_hook_flags_evt_extra (afb_hook_flags_evt_common\
299 |afb_hook_flag_evt_push_after|afb_hook_flag_evt_broadcast_after\
300 |afb_hook_flag_evt_create|afb_hook_flag_evt_drop)
301 #define afb_hook_flags_evt_all (afb_hook_flags_evt_extra|afb_hook_flag_evt_name)
303 struct afb_hook_evt_itf {
304 void (*hook_evt_create)(void *closure, const struct afb_hookid *hookid, const char *evt, int id);
305 void (*hook_evt_push_before)(void *closure, const struct afb_hookid *hookid, const char *evt, int id, struct json_object *obj);
306 void (*hook_evt_push_after)(void *closure, const struct afb_hookid *hookid, const char *evt, int id, struct json_object *obj, int result);
307 void (*hook_evt_broadcast_before)(void *closure, const struct afb_hookid *hookid, const char *evt, int id, struct json_object *obj);
308 void (*hook_evt_broadcast_after)(void *closure, const struct afb_hookid *hookid, const char *evt, int id, struct json_object *obj, int result);
309 void (*hook_evt_name)(void *closure, const struct afb_hookid *hookid, const char *evt, int id);
310 void (*hook_evt_drop)(void *closure, const struct afb_hookid *hookid, const char *evt, int id);
313 extern void afb_hook_evt_create(const char *evt, int id);
314 extern void afb_hook_evt_push_before(const char *evt, int id, struct json_object *obj);
315 extern int afb_hook_evt_push_after(const char *evt, int id, struct json_object *obj, int result);
316 extern void afb_hook_evt_broadcast_before(const char *evt, int id, struct json_object *obj);
317 extern int afb_hook_evt_broadcast_after(const char *evt, int id, struct json_object *obj, int result);
318 extern void afb_hook_evt_name(const char *evt, int id);
319 extern void afb_hook_evt_drop(const char *evt, int id);
321 extern int afb_hook_flags_evt(const char *name);
322 extern struct afb_hook_evt *afb_hook_create_evt(const char *pattern, int flags, struct afb_hook_evt_itf *itf, void *closure);
323 extern struct afb_hook_evt *afb_hook_addref_evt(struct afb_hook_evt *hook);
324 extern void afb_hook_unref_evt(struct afb_hook_evt *hook);
326 /*********************************************************
327 * section hooking global (global interface)
328 *********************************************************/
330 #define afb_hook_flag_global_vverbose 0x000001
332 #define afb_hook_flags_global_all (afb_hook_flag_global_vverbose)
334 struct afb_hook_global_itf {
335 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);
338 extern struct afb_hook_global *afb_hook_create_global(int flags, struct afb_hook_global_itf *itf, void *closure);
339 extern struct afb_hook_global *afb_hook_addref_global(struct afb_hook_global *hook);
340 extern void afb_hook_unref_global(struct afb_hook_global *hook);