diff --git a/openvasd/openvasd.c b/openvasd/openvasd.c index 3f24d09a..071fac47 100644 --- a/openvasd/openvasd.c +++ b/openvasd/openvasd.c @@ -17,7 +17,6 @@ #include #include #include -#include #include #include #include @@ -516,29 +515,34 @@ openvasd_get_version (openvasd_connector_t *conn) g_free (resp.ptr); return response; } - -struct curl_handlers -{ - CURLM *mhnd; - CURL *hnd; -}; - /** * @brief Wrapps a CURLM * handler */ -static curl_handler_t * -curlm_handler_new (void) +curlm_t +openvasd_curlm_handler_new (void) { - curl_handler_t *handlers = g_malloc0 (sizeof (curl_handler_t)); - return handlers; + CURLM *h = NULL; + return h; } void -openvasd_curl_handler_close (curl_handler_t *h) +openvasd_curl_handler_close (curlm_t *h) { - curl_multi_remove_handle (h->mhnd, h->hnd); - curl_easy_cleanup (h->hnd); - curl_multi_cleanup (h->mhnd); + int queued = 0; + + /* when an easy handle has completed, remove it */ + CURLMsg *msg = curl_multi_info_read (h, &queued); + if (msg) + { + if (msg->msg == CURLMSG_DONE) + { + curl_multi_remove_handle (h, msg->easy_handle); + curl_easy_cleanup (msg->easy_handle); + curl_multi_cleanup (h); + return; + } + g_warning ("%s: Not possible to clean up the curl handler", __func__); + } } /** @@ -552,15 +556,14 @@ openvasd_curl_handler_close (curl_handler_t *h) * @return The response. Null on error. */ openvasd_resp_t -openvasd_get_vts_stream_init (openvasd_connector_t *conn, curl_handler_t **h, +openvasd_get_vts_stream_init (openvasd_connector_t *conn, curlm_t *mhnd, stringstream *resp) { GString *path; openvasd_resp_t response = NULL; char *err = NULL; CURL *hnd = NULL; - - *h = curlm_handler_new (); + CURLM *h = NULL; response = g_malloc0 (sizeof (struct openvasd_response)); if (response == NULL) return NULL; @@ -576,9 +579,9 @@ openvasd_get_vts_stream_init (openvasd_connector_t *conn, curl_handler_t **h, } g_string_free (path, TRUE); - (*h)->mhnd = curl_multi_init (); - curl_multi_add_handle ((*h)->mhnd, hnd); - (*h)->hnd = hnd; + h = curl_multi_init (); + curl_multi_add_handle (h, hnd); + *mhnd = h; response->code = RESP_CODE_OK; return response; @@ -596,19 +599,19 @@ openvasd_get_vts_stream_init (openvasd_connector_t *conn, curl_handler_t **h, * transmision finished. -1 on error */ int -openvasd_get_vts_stream (curl_handler_t *h) +openvasd_get_vts_stream (curlm_t mhnd) { static int running = 0; - - if (!(h->mhnd)) + CURLM *h = mhnd; + if (!(h)) { return -1; } - CURLMcode mc = curl_multi_perform (h->mhnd, &running); + CURLMcode mc = curl_multi_perform (h, &running); if (!mc && running) /* wait for activity, timeout or "nothing" */ - mc = curl_multi_poll (h->mhnd, NULL, 0, 5000, NULL); + mc = curl_multi_poll (h, NULL, 0, 5000, NULL); if (mc != CURLM_OK) { g_warning ("%s: error on curl_multi_poll(): %d\n", __func__, mc); diff --git a/openvasd/openvasd.h b/openvasd/openvasd.h index d7635b9d..4496d57b 100644 --- a/openvasd/openvasd.h +++ b/openvasd/openvasd.h @@ -272,10 +272,7 @@ openvasd_build_scan_config_json (openvasd_target_t *, GHashTable *, GSList *); /* Curl multiperform wrapper */ -typedef struct curl_handlers curl_handler_t; - -void -openvasd_curl_handler_close (curl_handler_t *); +typedef void *curlm_t; /** @brief Define a string struct for storing the response. */ @@ -288,11 +285,16 @@ typedef struct string void init_stringstream (stringstream *s); +curlm_t +openvasd_curlm_handler_new (void); + +void +openvasd_curl_handler_close (curlm_t *); + openvasd_resp_t -openvasd_get_vts_stream_init (openvasd_connector_t *, curl_handler_t **, +openvasd_get_vts_stream_init (openvasd_connector_t *, curlm_t *, stringstream *); -int -openvasd_get_vts_stream (curl_handler_t *); +int openvasd_get_vts_stream (curlm_t); #endif diff --git a/openvasd/vtparser.c b/openvasd/vtparser.c index 98894304..8348f385 100644 --- a/openvasd/vtparser.c +++ b/openvasd/vtparser.c @@ -323,9 +323,11 @@ openvasd_parse_vt (gvm_json_pull_parser_t *parser, gvm_json_pull_event_t *event) g_debug ("%s: Start parsing feed", __func__); } else if (!g_strcmp0 (path, "$") - && event->type == GVM_JSON_PULL_EVENT_ARRAY_END) + && (event->type == GVM_JSON_PULL_EVENT_ARRAY_END + || event->type == GVM_JSON_PULL_EVENT_EOF)) { g_debug ("%s: Finish parsing feed", __func__); + g_free (path); return NULL; } g_free (path); @@ -333,7 +335,7 @@ openvasd_parse_vt (gvm_json_pull_parser_t *parser, gvm_json_pull_event_t *event) // It is an NVT object if (event->type != GVM_JSON_PULL_EVENT_OBJECT_START) { - g_message ("%s: Error reading VT object", __func__); + g_warning ("%s: Error reading VT object", __func__); return NULL; } diff --git a/util/jsonpull.c b/util/jsonpull.c index 792d2631..12df83b5 100644 --- a/util/jsonpull.c +++ b/util/jsonpull.c @@ -740,7 +740,7 @@ gvm_json_pull_parser_next (gvm_json_pull_parser_t *parser, return; } } - + event->path = parser->path; // Delayed addition to path after a container start element