X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=src%2Fafb-xreq.h;h=6da325ab5d680f44e38eb16cb8a4ccdb370152ea;hb=a8e971702f23ee67e02b4716ad4159f12cefdca6;hp=3376bb225070fb12138bbe338f7e9e663baefb74;hpb=522569c5a9da8566f5213fa5b9b3abadf746331d;p=src%2Fapp-framework-binder.git diff --git a/src/afb-xreq.h b/src/afb-xreq.h index 3376bb22..6da325ab 100644 --- a/src/afb-xreq.h +++ b/src/afb-xreq.h @@ -25,38 +25,43 @@ struct json_object; struct afb_evt_listener; +struct afb_xreq; +struct afb_cred; +struct afb_apiset; struct afb_xreq_query_itf { - struct json_object *(*json)(void *closure); - struct afb_arg (*get)(void *closure, const char *name); - void (*success)(void *closure, struct json_object *obj, const char *info); - void (*fail)(void *closure, const char *status, const char *info); - void (*reply)(void *closure, int iserror, struct json_object *obj); - void (*unref)(void *closure); - int (*subscribe)(void *closure, struct afb_event event); - int (*unsubscribe)(void *closure, struct afb_event event); - void (*subcall)(void *closure, const char *api, const char *verb, struct json_object *args, void (*callback)(void*, int, struct json_object*), void *cb_closure); + struct json_object *(*json)(struct afb_xreq *xreq); + struct afb_arg (*get)(struct afb_xreq *xreq, const char *name); + void (*success)(struct afb_xreq *xreq, struct json_object *obj, const char *info); + void (*fail)(struct afb_xreq *xreq, const char *status, const char *info); + void (*reply)(struct afb_xreq *xreq, int iserror, struct json_object *obj); + void (*unref)(struct afb_xreq *xreq); + int (*subscribe)(struct afb_xreq *xreq, struct afb_event event); + int (*unsubscribe)(struct afb_xreq *xreq, struct afb_event event); + void (*subcall)(struct afb_xreq *xreq, const char *api, const char *verb, struct json_object *args, void (*callback)(void*, int, struct json_object*), void *cb_closure); }; - /** * Internal data for requests */ struct afb_xreq { struct afb_context context; /**< context of the request */ + struct afb_apiset *apiset; /**< apiset of the xreq */ const char *api; /**< the requested API */ const char *verb; /**< the requested VERB */ struct json_object *json; /**< the json object (or NULL) */ - void *query; /**< closure for the query */ const struct afb_xreq_query_itf *queryitf; int refcount; /**< current ref count */ int replied; /**< is replied? */ int hookflags; /**< flags for hooking */ int hookindex; /**< index for hooking */ struct afb_evt_listener *listener; + struct afb_cred *cred; }; +#define CONTAINER_OF_XREQ(type,x) ((type*)(((intptr_t)(x))-((intptr_t)&(((type*)NULL)->xreq)))) + extern void afb_xreq_addref(struct afb_xreq *xreq); extern void afb_xreq_unref(struct afb_xreq *xreq); extern void afb_xreq_success(struct afb_xreq *xreq, struct json_object *obj, const char *info); @@ -67,7 +72,10 @@ extern const char *afb_xreq_raw(struct afb_xreq *xreq, size_t *size); extern int afb_xreq_subscribe(struct afb_xreq *xreq, struct afb_event event); extern int afb_xreq_unsubscribe(struct afb_xreq *xreq, struct afb_event event); extern void afb_xreq_subcall(struct afb_xreq *xreq, const char *api, const char *verb, struct json_object *args, void (*callback)(void*, int, struct json_object*), void *cb_closure); +extern void afb_xreq_unhooked_subcall(struct afb_xreq *xreq, const char *api, const char *verb, struct json_object *args, void (*callback)(void*, int, struct json_object*), void *cb_closure); +extern void afb_xreq_init(struct afb_xreq *xreq, const struct afb_xreq_query_itf *queryitf); extern void afb_xreq_begin(struct afb_xreq *xreq); -extern void afb_xreq_call(struct afb_xreq *xreq, int sessionflags, void (*callback)(struct afb_req req)); +extern void afb_xreq_so_call(struct afb_xreq *xreq, int sessionflags, void (*callback)(struct afb_req req)); +extern void afb_xreq_process(struct afb_xreq *xreq, struct afb_apiset *apiset);