diff options
author | José Bollo <jose.bollo@iot.bzh> | 2016-04-25 16:47:09 +0200 |
---|---|---|
committer | José Bollo <jose.bollo@iot.bzh> | 2016-04-25 16:49:39 +0200 |
commit | 97c02cb6f98727942bbbdd38b3ecbc1366894ed6 (patch) | |
tree | 6040886cee87fe5f1d468a919e5d1ebb74d03be3 | |
parent | 4644264333b29d58bc50085a9d97c74770b8b86a (diff) |
better handling of lengths
Change-Id: Ia5f440bd84d18155dbe26f311c3a070238c17444
Signed-off-by: José Bollo <jose.bollo@iot.bzh>
-rw-r--r-- | src/afb-hreq.c | 7 |
1 files changed, 3 insertions, 4 deletions
diff --git a/src/afb-hreq.c b/src/afb-hreq.c index d1ba0c13..2e74f2d4 100644 --- a/src/afb-hreq.c +++ b/src/afb-hreq.c @@ -39,7 +39,7 @@ #include "session.h" #include "verbose.h" -#define SIZE_RESPONSE_BUFFER 8000 +#define SIZE_RESPONSE_BUFFER 8192 static char empty_string[] = ""; @@ -657,7 +657,7 @@ static void req_send(struct afb_hreq *hreq, char *buffer, size_t size) static ssize_t send_json_cb(json_object *obj, uint64_t pos, char *buf, size_t max) { ssize_t len = stpncpy(buf, json_object_to_json_string(obj)+pos, max) - buf; - return len ? : -1; + return len ? : MHD_CONTENT_READER_END_OF_STREAM; } static void req_reply(struct afb_hreq *hreq, unsigned retcode, const char *status, const char *info, json_object *resp) @@ -673,8 +673,7 @@ static void req_reply(struct afb_hreq *hreq, unsigned retcode, const char *statu uuid = hreq->context->uuid; } reply = afb_msg_json_reply(status, info, resp, token, uuid); - - response = MHD_create_response_from_callback(MHD_SIZE_UNKNOWN, SIZE_RESPONSE_BUFFER, (void*)send_json_cb, reply, (void*)json_object_put); + response = MHD_create_response_from_callback((uint64_t)strlen(json_object_to_json_string(reply)), SIZE_RESPONSE_BUFFER, (void*)send_json_cb, reply, (void*)json_object_put); afb_hreq_reply(hreq, retcode, response, NULL); } |