From: Christian Grothoff Date: Mon, 4 Apr 2016 12:02:59 +0000 (+0000) Subject: add logic to parse JSON uploads X-Git-Tag: initial-import-from-subversion-38251~978 X-Git-Url: https://git.librecmc.org/?a=commitdiff_plain;h=50db224938033455429d17fce85ed77292d4c29a;p=oweals%2Fgnunet.git add logic to parse JSON uploads --- diff --git a/src/arm/gnunet-service-arm.c b/src/arm/gnunet-service-arm.c index 0ffda9331..ea89b2989 100644 --- a/src/arm/gnunet-service-arm.c +++ b/src/arm/gnunet-service-arm.c @@ -213,13 +213,13 @@ static char *final_option; /** * ID of task called whenever we get a SIGCHILD. */ -static struct GNUNET_SCHEDULER_Task * child_death_task; +static struct GNUNET_SCHEDULER_Task *child_death_task; /** * ID of task called whenever the timeout for restarting a child * expires. */ -static struct GNUNET_SCHEDULER_Task * child_restart_task; +static struct GNUNET_SCHEDULER_Task *child_restart_task; /** * Pipe used to communicate shutdown via signal. diff --git a/src/include/gnunet_json_lib.h b/src/include/gnunet_json_lib.h index 15e85c411..8b21c01dd 100644 --- a/src/include/gnunet_json_lib.h +++ b/src/include/gnunet_json_lib.h @@ -351,6 +351,72 @@ json_t * GNUNET_JSON_from_rsa_signature (const struct GNUNET_CRYPTO_RsaSignature *sig); +/* ******************* Helpers for MHD upload handling ******************* */ + +/** + * Return codes from #GNUNET_JSON_post_parser(). + */ +enum GNUNET_JSON_PostResult { + /** + * Parsing successful, JSON result is in `*json`. + */ + GNUNET_JSON_PR_SUCCESS, + + /** + * Parsing continues, call again soon! + */ + GNUNET_JSON_PR_CONTINUE, + + /** + * Sorry, memory allocation (malloc()) failed. + */ + GNUNET_JSON_PR_OUT_OF_MEMORY, + + /** + * Request size exceeded `buffer_max` argument. + */ + GNUNET_JSON_PR_REQUEST_TOO_LARGE, + + /** + * JSON parsing failed. This was not a JSON upload. + */ + GNUNET_JSON_PR_JSON_INVALID +}; + + +/** + * Process a POST request containing a JSON object. This function + * realizes an MHD POST processor that will (incrementally) process + * JSON data uploaded to the HTTP server. It will store the required + * state in the @a con_cls, which must be cleaned up using + * #GNUNET_JSON_post_parser_callback(). + * + * @param buffer_max maximum allowed size for the buffer + * @param con_cls the closure (will point to a `struct Buffer *`) + * @param upload_data the POST data + * @param upload_data_size number of bytes in @a upload_data + * @param json the JSON object for a completed request + * @return result code indicating the status of the operation + */ +enum GNUNET_JSON_PostResult +GNUNET_JSON_post_parser (size_t buffer_max, + void **con_cls, + const char *upload_data, + size_t *upload_data_size, + json_t **json); + + +/** + * Function called whenever we are done with a request + * to clean up our state. + * + * @param con_cls value as it was left by + * #GNUNET_JSON_post_parser(), to be cleaned up + */ +void +GNUNET_JSON_post_parser_cleanup (void *con_cls); + + #endif /* end of gnunet_json_lib.h */ diff --git a/src/util/program.c b/src/util/program.c index b24f3ed70..7023552f6 100644 --- a/src/util/program.c +++ b/src/util/program.c @@ -129,10 +129,10 @@ cmd_sorter (const void *a1, const void *a2) */ int GNUNET_PROGRAM_run2 (int argc, char *const *argv, const char *binaryName, - const char *binaryHelp, - const struct GNUNET_GETOPT_CommandLineOption *options, - GNUNET_PROGRAM_Main task, void *task_cls, - int run_without_scheduler) + const char *binaryHelp, + const struct GNUNET_GETOPT_CommandLineOption *options, + GNUNET_PROGRAM_Main task, void *task_cls, + int run_without_scheduler) { struct CommandContext cc; #if ENABLE_NLS