summaryrefslogtreecommitdiffstats
path: root/plugins/check_curl.c
diff options
context:
space:
mode:
authorAndreas Baumann <mail@andreasbaumann.cc>2023-02-12 13:16:25 +0100
committerAndreas Baumann <mail@andreasbaumann.cc>2023-02-12 13:16:25 +0100
commit6563267c3ad84bcc4779d282b5ae20520a4a2a6b (patch)
tree884c50eb035d40473741ab175dc194a94a74f991 /plugins/check_curl.c
parent40da85e6913ba4898f5a80772c7b3ea0cba0d3eb (diff)
downloadmonitoring-plugins-6563267c3ad84bcc4779d282b5ae20520a4a2a6b.tar.gz
fixed double frees when doing old-style redirects
Diffstat (limited to 'plugins/check_curl.c')
-rw-r--r--plugins/check_curl.c18
1 files changed, 14 insertions, 4 deletions
diff --git a/plugins/check_curl.c b/plugins/check_curl.c
index a49cac8a..1127d601 100644
--- a/plugins/check_curl.c
+++ b/plugins/check_curl.c
@@ -160,6 +160,8 @@ char *http_method = NULL;
160char *http_post_data = NULL; 160char *http_post_data = NULL;
161char *http_content_type = NULL; 161char *http_content_type = NULL;
162CURL *curl; 162CURL *curl;
163int curl_global_initialized = 0;
164int curl_easy_initialized = 0;
163struct curl_slist *header_list = NULL; 165struct curl_slist *header_list = NULL;
164int body_buf_initialized = 0; 166int body_buf_initialized = 0;
165curlhelp_write_curlbuf body_buf; 167curlhelp_write_curlbuf body_buf;
@@ -421,11 +423,17 @@ static void
421cleanup (void) 423cleanup (void)
422{ 424{
423 if (status_line_initialized) curlhelp_free_statusline(&status_line); 425 if (status_line_initialized) curlhelp_free_statusline(&status_line);
424 curl_easy_cleanup (curl); 426 status_line_initialized = 0;
425 curl_global_cleanup (); 427 if (curl_easy_initialized) curl_easy_cleanup (curl);
428 curl_easy_initialized = 0;
429 if (curl_global_initialized) curl_global_cleanup ();
430 curl_global_initialized = 0;
426 if (body_buf_initialized) curlhelp_freewritebuffer (&body_buf); 431 if (body_buf_initialized) curlhelp_freewritebuffer (&body_buf);
432 body_buf_initialized = 0;
427 if (header_buf_initialized) curlhelp_freewritebuffer (&header_buf); 433 if (header_buf_initialized) curlhelp_freewritebuffer (&header_buf);
434 header_buf_initialized = 0;
428 if (put_buf_initialized) curlhelp_freereadbuffer (&put_buf); 435 if (put_buf_initialized) curlhelp_freereadbuffer (&put_buf);
436 put_buf_initialized = 0;
429} 437}
430 438
431int 439int
@@ -442,11 +450,12 @@ check_http (void)
442 /* initialize curl */ 450 /* initialize curl */
443 if (curl_global_init (CURL_GLOBAL_DEFAULT) != CURLE_OK) 451 if (curl_global_init (CURL_GLOBAL_DEFAULT) != CURLE_OK)
444 die (STATE_UNKNOWN, "HTTP UNKNOWN - curl_global_init failed\n"); 452 die (STATE_UNKNOWN, "HTTP UNKNOWN - curl_global_init failed\n");
453 curl_global_initialized = 1;
445 454
446 if ((curl = curl_easy_init()) == NULL) { 455 if ((curl = curl_easy_init()) == NULL) {
447 curl_global_cleanup ();
448 die (STATE_UNKNOWN, "HTTP UNKNOWN - curl_easy_init failed\n"); 456 die (STATE_UNKNOWN, "HTTP UNKNOWN - curl_easy_init failed\n");
449 } 457 }
458 curl_easy_initialized = 1;
450 459
451 /* register cleanup function to shut down libcurl properly */ 460 /* register cleanup function to shut down libcurl properly */
452 atexit (cleanup); 461 atexit (cleanup);
@@ -903,6 +912,7 @@ GOT_FIRST_CERT:
903 /* we cannot know the major/minor version here for sure as we cannot parse the first line */ 912 /* we cannot know the major/minor version here for sure as we cannot parse the first line */
904 die (STATE_CRITICAL, "HTTP CRITICAL HTTP/x.x %ld unknown - %s", code, msg); 913 die (STATE_CRITICAL, "HTTP CRITICAL HTTP/x.x %ld unknown - %s", code, msg);
905 } 914 }
915 status_line_initialized = 1;
906 916
907 /* get result code from cURL */ 917 /* get result code from cURL */
908 handle_curl_option_return_code (curl_easy_getinfo (curl, CURLINFO_RESPONSE_CODE, &code), "CURLINFO_RESPONSE_CODE"); 918 handle_curl_option_return_code (curl_easy_getinfo (curl, CURLINFO_RESPONSE_CODE, &code), "CURLINFO_RESPONSE_CODE");
@@ -1234,6 +1244,7 @@ redir (curlhelp_write_curlbuf* header_buf)
1234 * attached to the URL in Location 1244 * attached to the URL in Location
1235 */ 1245 */
1236 1246
1247 cleanup ();
1237 check_http (); 1248 check_http ();
1238} 1249}
1239 1250
@@ -2167,7 +2178,6 @@ curlhelp_parse_statusline (const char *buf, curlhelp_statusline *status_line)
2167 2178
2168 first_line_len = (size_t)(first_line_end - buf); 2179 first_line_len = (size_t)(first_line_end - buf);
2169 status_line->first_line = (char *)malloc (first_line_len + 1); 2180 status_line->first_line = (char *)malloc (first_line_len + 1);
2170 status_line_initialized = 1;
2171 if (status_line->first_line == NULL) return -1; 2181 if (status_line->first_line == NULL) return -1;
2172 memcpy (status_line->first_line, buf, first_line_len); 2182 memcpy (status_line->first_line, buf, first_line_len);
2173 status_line->first_line[first_line_len] = '\0'; 2183 status_line->first_line[first_line_len] = '\0';