#pragma once
+#include <stdarg.h>
+
struct req;
struct afb_context;
struct json_object;
#define afb_hook_flag_req_subcall_result 0x010800
#define afb_hook_flag_req_subcallsync 0x020000
#define afb_hook_flag_req_subcallsync_result 0x040000
+#define afb_hook_flag_req_vverbose 0x080000
/* common flags */
#define afb_hook_flags_req_life (afb_hook_flag_req_begin|afb_hook_flag_req_end)
/* predefined groups */
#define afb_hook_flags_req_common (afb_hook_flags_req_life|afb_hook_flags_req_args|afb_hook_flags_req_result\
- |afb_hook_flags_req_session|afb_hook_flags_req_event|afb_hook_flags_req_subcall)
+ |afb_hook_flags_req_session|afb_hook_flags_req_event|afb_hook_flags_req_subcall\
+ |afb_hook_flag_req_vverbose)
#define afb_hook_flags_req_extra (afb_hook_flags_req_common|afb_hook_flags_req_ref|afb_hook_flags_req_context)
#define afb_hook_flags_req_all (afb_hook_flags_req_extra)
void (*hook_xreq_subcall_result)(void * closure, const struct afb_xreq *xreq, int status, struct json_object *result);
void (*hook_xreq_subcallsync)(void * closure, const struct afb_xreq *xreq, const char *api, const char *verb, struct json_object *args);
void (*hook_xreq_subcallsync_result)(void * closure, const struct afb_xreq *xreq, int status, struct json_object *result);
+ void (*hook_xreq_vverbose)(void * closure, const struct afb_xreq *xreq, int level, const char *file, int line, const char *func, const char *fmt, va_list args);
};
extern void afb_hook_init_xreq(struct afb_xreq *xreq);
extern void afb_hook_xreq_subcall_result(const struct afb_xreq *xreq, int status, struct json_object *result);
extern void afb_hook_xreq_subcallsync(const struct afb_xreq *xreq, const char *api, const char *verb, struct json_object *args);
extern int afb_hook_xreq_subcallsync_result(const struct afb_xreq *xreq, int status, struct json_object *result);
+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);
/*********************************************************
* section hooking ditf (daemon interface)
* section hooking svc (service interface)
*********************************************************/
-#define afb_hook_flag_svc_start_before 0x000001
-#define afb_hook_flag_svc_start_after 0x000002
-#define afb_hook_flag_svc_on_event_before 0x000004
-#define afb_hook_flag_svc_on_event_after 0x000008
-#define afb_hook_flag_svc_call 0x000010
-#define afb_hook_flag_svc_call_result 0x000020
-#define afb_hook_flag_svc_callsync 0x000040
-#define afb_hook_flag_svc_callsync_result 0x000080
+#define afb_hook_flag_svc_start_before 0x000001
+#define afb_hook_flag_svc_start_after 0x000002
+#define afb_hook_flag_svc_on_event_before 0x000004
+#define afb_hook_flag_svc_on_event_after 0x000008
+#define afb_hook_flag_svc_call 0x000010
+#define afb_hook_flag_svc_call_result 0x000020
+#define afb_hook_flag_svc_callsync 0x000040
+#define afb_hook_flag_svc_callsync_result 0x000080
#define afb_hook_flags_svc_all (afb_hook_flag_svc_start_before|afb_hook_flag_svc_start_after\
|afb_hook_flag_svc_on_event_before|afb_hook_flag_svc_on_event_after\
extern struct afb_hook_svc *afb_hook_addref_svc(struct afb_hook_svc *hook);
extern void afb_hook_unref_svc(struct afb_hook_svc *hook);
+/*********************************************************
+* section hooking evt (event interface)
+*********************************************************/
+
+#define afb_hook_flag_evt_create 0x000001
+#define afb_hook_flag_evt_push_before 0x000002
+#define afb_hook_flag_evt_push_after 0x000004
+#define afb_hook_flag_evt_broadcast_before 0x000008
+#define afb_hook_flag_evt_broadcast_after 0x000010
+#define afb_hook_flag_evt_name 0x000020
+#define afb_hook_flag_evt_drop 0x000040
+
+#define afb_hook_flags_evt_common (afb_hook_flag_evt_push_before|afb_hook_flag_evt_broadcast_before)
+#define afb_hook_flags_evt_extra (afb_hook_flags_evt_common\
+ |afb_hook_flag_evt_push_after|afb_hook_flag_evt_broadcast_after\
+ |afb_hook_flag_evt_create|afb_hook_flag_evt_drop)
+#define afb_hook_flags_evt_all (afb_hook_flags_evt_extra|afb_hook_flag_evt_name)
+
+struct afb_hook_evt_itf {
+ void (*hook_evt_create)(void *closure, const char *evt, int id);
+ void (*hook_evt_push_before)(void *closure, const char *evt, int id, struct json_object *obj);
+ void (*hook_evt_push_after)(void *closure, const char *evt, int id, struct json_object *obj, int result);
+ void (*hook_evt_broadcast_before)(void *closure, const char *evt, int id, struct json_object *obj);
+ void (*hook_evt_broadcast_after)(void *closure, const char *evt, int id, struct json_object *obj, int result);
+ void (*hook_evt_name)(void *closure, const char *evt, int id);
+ void (*hook_evt_drop)(void *closure, const char *evt, int id);
+};
+
+extern void afb_hook_evt_create(const char *evt, int id);
+extern void afb_hook_evt_push_before(const char *evt, int id, struct json_object *obj);
+extern int afb_hook_evt_push_after(const char *evt, int id, struct json_object *obj, int result);
+extern void afb_hook_evt_broadcast_before(const char *evt, int id, struct json_object *obj);
+extern int afb_hook_evt_broadcast_after(const char *evt, int id, struct json_object *obj, int result);
+extern void afb_hook_evt_name(const char *evt, int id);
+extern void afb_hook_evt_drop(const char *evt, int id);
+
+extern int afb_hook_flags_evt(const char *name);
+extern struct afb_hook_evt *afb_hook_create_evt(const char *name, int flags, struct afb_hook_evt_itf *itf, void *closure);
+extern struct afb_hook_evt *afb_hook_addref_evt(struct afb_hook_evt *hook);
+extern void afb_hook_unref_evt(struct afb_hook_evt *hook);
+