From b5689a8d470d8d107daeace1c05024f5a35114ed Mon Sep 17 00:00:00 2001 From: Bastian Dehn Date: Tue, 21 May 2024 20:20:18 +0200 Subject: [PATCH] change stop scan with memory stream --- src/kds_s2000w_client.c | 17 +++++++++++++++-- 1 file changed, 15 insertions(+), 2 deletions(-) diff --git a/src/kds_s2000w_client.c b/src/kds_s2000w_client.c index e7375d1..f93c6c4 100644 --- a/src/kds_s2000w_client.c +++ b/src/kds_s2000w_client.c @@ -319,6 +319,9 @@ int kds_s2000w_client_stop_scan(int64_t sessionid, response* response) struct curl_slist* headers = NULL; CURLcode result = 0; char header_str[80]; + FILE* stream = NULL; + char* buffer = NULL; + size_t* sizeloc = NULL; curl = curl_easy_init(); if(!curl) @@ -336,8 +339,10 @@ int kds_s2000w_client_stop_scan(int64_t sessionid, response* response) curl_easy_setopt(curl, CURLOPT_URL, url); curl_easy_setopt(curl, CURLOPT_POST, 1L); curl_easy_setopt(curl, CURLOPT_POSTFIELDSIZE, 0L); - curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, _kds_s2000w_client_callback); - curl_easy_setopt(curl, CURLOPT_WRITEDATA, (void*) response); + buffer = malloc(sizeof(char)); + sizeloc = malloc(sizeof(size_t)); + stream = open_memstream(&buffer, sizeloc); + curl_easy_setopt(curl, CURLOPT_WRITEDATA, stream); curl_easy_setopt(curl, CURLOPT_SSL_VERIFYPEER, 0L); curl_easy_setopt(curl, CURLOPT_SSL_VERIFYHOST, 0L); result = curl_easy_perform(curl); @@ -347,12 +352,20 @@ int kds_s2000w_client_stop_scan(int64_t sessionid, response* response) if (result != CURLE_OK) fprintf(stderr, "ERROR: curl_easy_perform: %s\n", curl_easy_strerror(result)); + fflush(stream); + _kds_s2000w_client_stream_to_response(stream, response, sizeloc); + fclose(stream); + curl_url_cleanup(url_handler); url_handler = NULL; curl_free(url); url = NULL; curl_easy_cleanup(curl); curl = NULL; + free(buffer); + buffer = NULL; + free(sizeloc); + sizeloc = NULL; return result; } -- 2.39.5