projects
/
trust_router.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
tid_req: Store json references
[trust_router.git]
/
include
/
trust_router
/
tid.h
diff --git
a/include/trust_router/tid.h
b/include/trust_router/tid.h
index
74281ca
..
2b580bb
100644
(file)
--- a/
include/trust_router/tid.h
+++ b/
include/trust_router/tid.h
@@
-73,6
+73,7
@@
typedef struct tid_resp {
typedef struct tidc_instance TIDC_INSTANCE;
typedef struct tids_instance TIDS_INSTANCE;
typedef struct tid_req TID_REQ;
typedef struct tidc_instance TIDC_INSTANCE;
typedef struct tids_instance TIDS_INSTANCE;
typedef struct tid_req TID_REQ;
+typedef struct json_t json_t;
typedef void (TIDC_RESP_FUNC)(TIDC_INSTANCE *, TID_REQ *, TID_RESP *, void *);
typedef void (TIDC_RESP_FUNC)(TIDC_INSTANCE *, TID_REQ *, TID_RESP *, void *);
@@
-90,6
+91,7
@@
struct tid_req {
DH *tidc_dh; /* Client's public dh information */
TIDC_RESP_FUNC *resp_func;
void *cookie;
DH *tidc_dh; /* Client's public dh information */
TIDC_RESP_FUNC *resp_func;
void *cookie;
+ json_t *json_references; /** References to objects dereferenced on request destruction*/
};
struct tidc_instance {
};
struct tidc_instance {
@@
-114,7
+116,8
@@
struct tids_instance {
void *cookie;
};
void *cookie;
};
-/* Utility funciton for TID_REQ structures, in tid/tid_req.c */
+/* Utility functions for TID_REQ structures, in tid/tid_req.c */
+TR_EXPORT TID_REQ *tid_req_new(void);
TR_EXPORT TID_REQ *tid_req_get_next_req(TID_REQ *req);
void tid_req_set_next_req(TID_REQ *req, TID_REQ *next_req);
TR_EXPORT int tid_req_get_resp_sent(TID_REQ *req);
TR_EXPORT TID_REQ *tid_req_get_next_req(TID_REQ *req);
void tid_req_set_next_req(TID_REQ *req, TID_REQ *next_req);
TR_EXPORT int tid_req_get_resp_sent(TID_REQ *req);
@@
-139,6
+142,11
@@
TR_EXPORT void *tid_req_get_cookie(TID_REQ *req);
void tid_req_set_cookie(TID_REQ *req, void *cookie);
TR_EXPORT TID_REQ *tid_dup_req (TID_REQ *orig_req);
void tid_req_set_cookie(TID_REQ *req, void *cookie);
TR_EXPORT TID_REQ *tid_dup_req (TID_REQ *orig_req);
+/** Decrement a reference to #json when this tid_req is cleaned up. A
+ new reference is not created; in effect the caller is handing a
+ reference they already hold to the TID_REQ.*/
+void tid_req_cleanup_json(TID_REQ *, json_t *json);
+
/* Utility functions for TID_RESP structure, in tid/tid_resp.c */
TR_EXPORT TID_RC tid_resp_get_result(TID_RESP *resp);
void tid_resp_set_result(TID_RESP *resp, TID_RC result);
/* Utility functions for TID_RESP structure, in tid/tid_resp.c */
TR_EXPORT TID_RC tid_resp_get_result(TID_RESP *resp);
void tid_resp_set_result(TID_RESP *resp, TID_RC result);