]> gitweb.hhaalo.de Git - sane-kds-s2000w-net.git/commitdiff
optimize set option
authorBastian Dehn <hhaalo@arcor.de>
Wed, 15 Oct 2025 07:32:15 +0000 (09:32 +0200)
committerBastian Dehn <hhaalo@arcor.de>
Wed, 15 Oct 2025 07:32:15 +0000 (09:32 +0200)
src/kds_s2000w_client.c

index 8d039280f3832cfad8e892080fb62c77e5c44744..850839fc2e4f5438f5609a3b346142673c25159b 100644 (file)
@@ -542,57 +542,25 @@ uint8_t kds_s2000w_client_set_option(int64_t sessionid, response* resp)
 {
        kds_s2000w_debug_printf(ALL, "kds_s2000w_client_set_option");
 
-       CURL* curl = curl_easy_init();
-       char* url = NULL;
-       CURLU* url_handler = curl_url();
-       curl_url_set(url_handler, CURLUPART_URL, client_config->scanner_url, 0);
-       curl_url_set(url_handler, CURLUPART_PATH, CONFIGURATION_PATH, 0);
-       curl_url_get(url_handler, CURLUPART_URL, &url, 0);
-       curl_easy_setopt(curl, CURLOPT_URL, url);
-
-       struct curl_slist* headers = NULL;
-       char* header_str = malloc(sizeof(char) * MAX_STR_BUFFER_LENGTH);
-       if (header_str == NULL) {
-               curl_url_cleanup(url_handler);
-               url_handler = NULL;
-               curl_free(url);
-               url = NULL;
-               return 1;
-       }
+       curl_param_t* param = _kds_s2000w_client_param_init(sessionid);
+       if (param == NULL)
+               return CURLE_OUT_OF_MEMORY;
 
-       memset(header_str, 0, MAX_STR_BUFFER_LENGTH);
-       sprintf(header_str, "SessionId: %li", sessionid);
-       headers = curl_slist_append(headers, header_str);
-       headers = curl_slist_append(headers, CONTENT_TYPE_HEADER);
-       headers = curl_slist_append(headers, ACCEPT_JSON_HEADER);
-       curl_easy_setopt(curl, CURLOPT_HTTPHEADER, headers);
-
-       curl_easy_setopt(curl, CURLOPT_POSTFIELDS, resp->data);
-       curl_easy_setopt(curl, CURLOPT_POSTFIELDSIZE, resp->size);
-       curl_easy_setopt(curl, CURLOPT_CUSTOMREQUEST, HTTP_PUT);
-       _kds_s2000w_client_set_ssl_verification_off(curl);
-
-       char* errbuf = _kds_s2000w_client_errbuf_init();
-       curl_easy_setopt(curl, CURLOPT_ERRORBUFFER, errbuf);
-       _kds_s2000w_client_set_verbose(curl);
-       CURLcode result = curl_easy_perform(curl);
-       curl_easy_getinfo(curl, CURLINFO_RESPONSE_CODE, &resp->code);
-
-       _kds_s2000w_client_print_error_status(curl);
-       _kds_s2000w_client_print_error_result(result, errbuf);
-
-       curl_url_cleanup(url_handler);
-       url_handler = NULL;
-       curl_slist_free_all(headers);
-       headers = NULL;
-       curl_free(url);
-       url = NULL;
-       curl_easy_cleanup(curl);
-       curl = NULL;
-       free(header_str);
-       header_str = NULL;
-       free(errbuf);
-       errbuf = NULL;
+       curl_url_set(param->url_handler, CURLUPART_URL, client_config->scanner_url, 0);
+       curl_url_set(param->url_handler, CURLUPART_PATH, CONFIGURATION_PATH, 0);
+       curl_url_get(param->url_handler, CURLUPART_URL, &param->url, 0);
+       curl_easy_setopt(param->curl, CURLOPT_URL, param->url);
+       curl_easy_setopt(param->curl, CURLOPT_POSTFIELDS, resp->data);
+       curl_easy_setopt(param->curl, CURLOPT_POSTFIELDSIZE, resp->size);
+       curl_easy_setopt(param->curl, CURLOPT_CUSTOMREQUEST, HTTP_PUT);
+       CURLcode result = curl_easy_perform(param->curl);
+       curl_easy_getinfo(param->curl, CURLINFO_RESPONSE_CODE, &resp->code);
+
+       _kds_s2000w_client_print_error_status(param->curl);
+       _kds_s2000w_client_print_error_result(result, param->errbuf);
+
+       _kds_s2000w_client_param_free(param);
+       param = NULL;
 
        return result;
 }
\ No newline at end of file