X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=src%2Fafb-hook.h;h=8fe30d5b0d82b67854d76b022ff6479c8ebeb856;hb=78867fd5c3c67839116b89d636b2f191fc14f4e1;hp=d1f6371a5cede574c5dbfd07adb1fe7c010739ae;hpb=05e0214d821f1a7604b4a0897907f347761b56e6;p=src%2Fapp-framework-binder.git diff --git a/src/afb-hook.h b/src/afb-hook.h index d1f6371a..8fe30d5b 100644 --- a/src/afb-hook.h +++ b/src/afb-hook.h @@ -25,6 +25,7 @@ struct afb_event; struct afb_session; struct afb_xreq; struct afb_ditf; +struct afb_svc; struct sd_bus; struct sd_event; @@ -40,20 +41,18 @@ struct afb_hook_xreq; #define afb_hook_flag_req_get 0x000008 #define afb_hook_flag_req_success 0x000010 #define afb_hook_flag_req_fail 0x000020 -#define afb_hook_flag_req_raw 0x000040 -#define afb_hook_flag_req_send 0x000080 -#define afb_hook_flag_req_context_get 0x000100 -#define afb_hook_flag_req_context_set 0x000200 -#define afb_hook_flag_req_addref 0x000400 -#define afb_hook_flag_req_unref 0x000800 -#define afb_hook_flag_req_session_close 0x001000 -#define afb_hook_flag_req_session_set_LOA 0x002000 -#define afb_hook_flag_req_subscribe 0x004000 -#define afb_hook_flag_req_unsubscribe 0x010800 -#define afb_hook_flag_req_subcall 0x020000 -#define afb_hook_flag_req_subcall_result 0x040000 -#define afb_hook_flag_req_subcallsync 0x080000 -#define afb_hook_flag_req_subcallsync_result 0x100000 +#define afb_hook_flag_req_context_get 0x000040 +#define afb_hook_flag_req_context_set 0x000080 +#define afb_hook_flag_req_addref 0x000100 +#define afb_hook_flag_req_unref 0x000200 +#define afb_hook_flag_req_session_close 0x000400 +#define afb_hook_flag_req_session_set_LOA 0x000800 +#define afb_hook_flag_req_subscribe 0x001000 +#define afb_hook_flag_req_unsubscribe 0x002000 +#define afb_hook_flag_req_subcall 0x004000 +#define afb_hook_flag_req_subcall_result 0x010800 +#define afb_hook_flag_req_subcallsync 0x020000 +#define afb_hook_flag_req_subcallsync_result 0x040000 /* common flags */ #define afb_hook_flags_req_life (afb_hook_flag_req_begin|afb_hook_flag_req_end) @@ -68,14 +67,11 @@ struct afb_hook_xreq; #define afb_hook_flags_req_ref (afb_hook_flag_req_addref|afb_hook_flag_req_unref) #define afb_hook_flags_req_context (afb_hook_flag_req_context_get|afb_hook_flag_req_context_set) -/* internal flags */ -#define afb_hook_flags_req_internal (afb_hook_flag_req_raw|afb_hook_flag_req_send) - /* 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) #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|afb_hook_flags_req_internal) +#define afb_hook_flags_req_all (afb_hook_flags_req_extra) struct afb_hook_xreq_itf { void (*hook_xreq_begin)(void * closure, const struct afb_xreq *xreq); @@ -84,8 +80,6 @@ struct afb_hook_xreq_itf { void (*hook_xreq_get)(void * closure, const struct afb_xreq *xreq, const char *name, struct afb_arg arg); void (*hook_xreq_success)(void * closure, const struct afb_xreq *xreq, struct json_object *obj, const char *info); void (*hook_xreq_fail)(void * closure, const struct afb_xreq *xreq, const char *status, const char *info); - void (*hook_xreq_raw)(void * closure, const struct afb_xreq *xreq, const char *buffer, size_t size); - void (*hook_xreq_send)(void * closure, const struct afb_xreq *xreq, const char *buffer, size_t size); void (*hook_xreq_context_get)(void * closure, const struct afb_xreq *xreq, void *value); void (*hook_xreq_context_set)(void * closure, const struct afb_xreq *xreq, void *value, void (*free_value)(void*)); void (*hook_xreq_addref)(void * closure, const struct afb_xreq *xreq); @@ -113,8 +107,6 @@ extern struct json_object *afb_hook_xreq_json(const struct afb_xreq *xreq, struc extern struct afb_arg afb_hook_xreq_get(const struct afb_xreq *xreq, const char *name, struct afb_arg arg); extern void afb_hook_xreq_success(const struct afb_xreq *xreq, struct json_object *obj, const char *info); extern void afb_hook_xreq_fail(const struct afb_xreq *xreq, const char *status, const char *info); -extern const char *afb_hook_xreq_raw(const struct afb_xreq *xreq, const char *buffer, size_t size); -extern void afb_hook_xreq_send(const struct afb_xreq *xreq, const char *buffer, size_t size); extern void *afb_hook_xreq_context_get(const struct afb_xreq *xreq, void *value); extern void afb_hook_xreq_context_set(const struct afb_xreq *xreq, void *value, void (*free_value)(void*)); extern void afb_hook_xreq_addref(const struct afb_xreq *xreq); @@ -129,7 +121,7 @@ extern void afb_hook_xreq_subcallsync(const struct afb_xreq *xreq, const char *a extern int afb_hook_xreq_subcallsync_result(const struct afb_xreq *xreq, int status, struct json_object *result); /********************************************************* -* section hooking ditf +* section hooking ditf (daemon interface) *********************************************************/ #define afb_hook_flag_ditf_vverbose 0x000001 @@ -185,3 +177,46 @@ extern struct afb_hook_ditf *afb_hook_create_ditf(const char *api, int flags, st extern struct afb_hook_ditf *afb_hook_addref_ditf(struct afb_hook_ditf *hook); extern void afb_hook_unref_ditf(struct afb_hook_ditf *hook); +/********************************************************* +* 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_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\ + |afb_hook_flag_svc_call|afb_hook_flag_svc_call_result\ + |afb_hook_flag_svc_callsync|afb_hook_flag_svc_callsync_result) + +struct afb_hook_svc_itf { + void (*hook_svc_start_before)(void *closure, const struct afb_svc *svc); + void (*hook_svc_start_after)(void *closure, const struct afb_svc *svc, int status); + void (*hook_svc_on_event_before)(void *closure, const struct afb_svc *svc, const char *event, int eventid, struct json_object *object); + void (*hook_svc_on_event_after)(void *closure, const struct afb_svc *svc, const char *event, int eventid, struct json_object *object); + void (*hook_svc_call)(void *closure, const struct afb_svc *svc, const char *api, const char *verb, struct json_object *args); + void (*hook_svc_call_result)(void *closure, const struct afb_svc *svc, int status, struct json_object *result); + void (*hook_svc_callsync)(void *closure, const struct afb_svc *svc, const char *api, const char *verb, struct json_object *args); + void (*hook_svc_callsync_result)(void *closure, const struct afb_svc *svc, int status, struct json_object *result); +}; + +extern void afb_hook_svc_start_before(const struct afb_svc *svc); +extern int afb_hook_svc_start_after(const struct afb_svc *svc, int status); +extern void afb_hook_svc_on_event_before(const struct afb_svc *svc, const char *event, int eventid, struct json_object *object); +extern void afb_hook_svc_on_event_after(const struct afb_svc *svc, const char *event, int eventid, struct json_object *object); +extern void afb_hook_svc_call(const struct afb_svc *svc, const char *api, const char *verb, struct json_object *args); +extern void afb_hook_svc_call_result(const struct afb_svc *svc, int status, struct json_object *result); +extern void afb_hook_svc_callsync(const struct afb_svc *svc, const char *api, const char *verb, struct json_object *args); +extern int afb_hook_svc_callsync_result(const struct afb_svc *svc, int status, struct json_object *result); + +extern int afb_hook_flags_svc(const char *api); +extern struct afb_hook_svc *afb_hook_create_svc(const char *api, int flags, struct afb_hook_svc_itf *itf, void *closure); +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); +