Bladeren bron

check_http --onredirect=sticky follows using the same IP address (sf.net #2550208).

Thomas Guyot-Sionnest 17 jaren geleden
bovenliggende
commit
d00a53dd1e
2 gewijzigde bestanden met toevoegingen van 12 en 5 verwijderingen
  1. 1 0
      NEWS
  2. 11 5
      plugins/check_http.c

+ 1 - 0
NEWS

@@ -20,6 +20,7 @@ This file documents the major additions and syntax changes between releases.
 	Re-bundled libtap as a built-in library (--enable-libtap): detects system library as pre-1.4.13 and does not install the built-in library anymore
 	Re-bundled libtap as a built-in library (--enable-libtap): detects system library as pre-1.4.13 and does not install the built-in library anymore
 	Fixed check_mrtg returning UNKNOWN instead of OK (bug #2378068)
 	Fixed check_mrtg returning UNKNOWN instead of OK (bug #2378068)
 	Fixed check_http behaviour: all check are now performed as long as a valid response is returned (sf.net #1460312)
 	Fixed check_http behaviour: all check are now performed as long as a valid response is returned (sf.net #1460312)
+	check_http --onredirect=sticky follows using the same IP address (sf.net #2550208).
 
 
 1.4.13 25th Sept 2008
 1.4.13 25th Sept 2008
 	Fix Debian bug #460097: check_http --max-age broken (Hilko Bengen)
 	Fix Debian bug #460097: check_http --max-age broken (Hilko Bengen)

+ 11 - 5
plugins/check_http.c

@@ -106,6 +106,7 @@ int display_html = FALSE;
 char **http_opt_headers;
 char **http_opt_headers;
 int http_opt_headers_count = 0;
 int http_opt_headers_count = 0;
 int onredirect = STATE_OK;
 int onredirect = STATE_OK;
+int followsticky = 0;
 int use_ssl = FALSE;
 int use_ssl = FALSE;
 int verbose = FALSE;
 int verbose = FALSE;
 int sd;
 int sd;
@@ -299,8 +300,10 @@ process_arguments (int argc, char **argv)
         server_port = HTTPS_PORT;
         server_port = HTTPS_PORT;
       break;
       break;
     case 'f': /* onredirect */
     case 'f': /* onredirect */
+      if (!strcmp (optarg, "sticky"))
+        onredirect = STATE_DEPENDENT, followsticky = 1;
       if (!strcmp (optarg, "follow"))
       if (!strcmp (optarg, "follow"))
-        onredirect = STATE_DEPENDENT;
+        onredirect = STATE_DEPENDENT, followsticky = 0;
       if (!strcmp (optarg, "unknown"))
       if (!strcmp (optarg, "unknown"))
         onredirect = STATE_UNKNOWN;
         onredirect = STATE_UNKNOWN;
       if (!strcmp (optarg, "ok"))
       if (!strcmp (optarg, "ok"))
@@ -1200,8 +1203,10 @@ redir (char *pos, char *status_line)
   free (host_name);
   free (host_name);
   host_name = strdup (addr);
   host_name = strdup (addr);
 
 
-  free (server_address);
-  server_address = strdup (addr);
+  if (followsticky == 0) {
+    free (server_address);
+    server_address = strdup (addr);
+  }
 
 
   free (server_url);
   free (server_url);
   server_url = url;
   server_url = url;
@@ -1338,8 +1343,9 @@ print_help (void)
   printf ("    %s\n", _(" Any other tags to be sent in http header. Use multiple times for additional headers"));
   printf ("    %s\n", _(" Any other tags to be sent in http header. Use multiple times for additional headers"));
   printf (" %s\n", "-L, --link");
   printf (" %s\n", "-L, --link");
   printf ("    %s\n", _("Wrap output in HTML link (obsoleted by urlize)"));
   printf ("    %s\n", _("Wrap output in HTML link (obsoleted by urlize)"));
-  printf (" %s\n", "-f, --onredirect=<ok|warning|critical|follow>");
-  printf ("    %s\n", _("How to handle redirected pages"));
+  printf (" %s\n", "-f, --onredirect=<ok|warning|critical|follow|sticky>");
+  printf ("    %s\n", _("How to handle redirected pages. sticky is like follow but stick to the"));
+  printf ("    %s\n", _("specified IP address"));
   printf (" %s\n", "-m, --pagesize=INTEGER<:INTEGER>");
   printf (" %s\n", "-m, --pagesize=INTEGER<:INTEGER>");
   printf ("    %s\n", _("Minimum page size required (bytes) : Maximum page size required (bytes)"));
   printf ("    %s\n", _("Minimum page size required (bytes) : Maximum page size required (bytes)"));