X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=src%2Fafb-xreq.h;h=3b8a590cb031f2a2e1c196972fff4e96ab58c84b;hb=f9f80fd77b5a6a9b50fac3026fae088823a23dc1;hp=42824d7d831794ed05bc2c4168c44a15100edc90;hpb=6797f9722dd3e5463e0f7c118397955bb59a40c7;p=src%2Fapp-framework-binder.git diff --git a/src/afb-xreq.h b/src/afb-xreq.h index 42824d7d..3b8a590c 100644 --- a/src/afb-xreq.h +++ b/src/afb-xreq.h @@ -31,7 +31,7 @@ struct afb_xreq_query_itf { 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, struct json_object *obj); + 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); @@ -45,8 +45,9 @@ struct afb_xreq_query_itf { struct afb_xreq { struct afb_context context; /**< context of the request */ - char *api; /**< the requested API */ - char *verb; /**< the requested VERB */ + 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 */ @@ -60,7 +61,12 @@ struct afb_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); +extern void afb_xreq_fail(struct afb_xreq *xreq, const char *status, const char *info); extern void afb_xreq_fail_f(struct afb_xreq *xreq, const char *status, const char *info, ...); extern void afb_xreq_success_f(struct afb_xreq *xreq, struct json_object *obj, const char *info, ...); extern void afb_xreq_call(struct afb_xreq *xreq); +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);