Blame SOURCES/mod_security-2.9.2-remote-rules-timeout.patch

c6dbd2
diff --git a/apache2/apache2_config.c b/apache2/apache2_config.c
c6dbd2
index ce97950..5d4e9b5 100644
c6dbd2
--- a/apache2/apache2_config.c
c6dbd2
+++ b/apache2/apache2_config.c
c6dbd2
@@ -2345,6 +2345,24 @@ static const char *cmd_remote_rules(cmd_parms *cmd, void *_dcfg, const char *p1,
c6dbd2
 }
c6dbd2
 
c6dbd2
 
c6dbd2
+static const char *cmd_remote_timeout(cmd_parms *cmd, void *_dcfg, const char *p1)
c6dbd2
+{
c6dbd2
+    directory_config *dcfg = (directory_config *)_dcfg;
c6dbd2
+    long int timeout;
c6dbd2
+
c6dbd2
+    if (dcfg == NULL) return NULL;
c6dbd2
+
c6dbd2
+    timeout = strtol(p1, NULL, 10);
c6dbd2
+    if ((timeout == LONG_MAX)||(timeout == LONG_MIN)||(timeout < 0)) {
c6dbd2
+        return apr_psprintf(cmd->pool, "ModSecurity: Invalid value for SecRemoteTimeout: %s", p1);
c6dbd2
+    }
c6dbd2
+
c6dbd2
+    remote_rules_timeout = timeout;
c6dbd2
+
c6dbd2
+    return NULL;
c6dbd2
+}
c6dbd2
+
c6dbd2
+
c6dbd2
 static const char *cmd_status_engine(cmd_parms *cmd, void *_dcfg, const char *p1)
c6dbd2
 {
c6dbd2
     if (strcasecmp(p1, "on") == 0) {
c6dbd2
@@ -3658,6 +3677,14 @@ const command_rec module_directives[] = {
c6dbd2
         "Abort or Warn"
c6dbd2
     ),
c6dbd2
 
c6dbd2
+    AP_INIT_TAKE1 (
c6dbd2
+        "SecRemoteTimeout",
c6dbd2
+        cmd_remote_timeout,
c6dbd2
+        NULL,
c6dbd2
+        CMD_SCOPE_ANY,
c6dbd2
+        "timeout in seconds"
c6dbd2
+    ),
c6dbd2
+
c6dbd2
 
c6dbd2
     AP_INIT_TAKE1 (
c6dbd2
         "SecXmlExternalEntity",
c6dbd2
diff --git a/apache2/mod_security2.c b/apache2/mod_security2.c
c6dbd2
index b6e98e9..1410ac7 100644
c6dbd2
--- a/apache2/mod_security2.c
c6dbd2
+++ b/apache2/mod_security2.c
c6dbd2
@@ -79,6 +79,8 @@ msc_remote_rules_server DSOLOCAL *remote_rules_server = NULL;
c6dbd2
 #endif
c6dbd2
 int DSOLOCAL remote_rules_fail_action = REMOTE_RULES_ABORT_ON_FAIL;
c6dbd2
 char DSOLOCAL *remote_rules_fail_message = NULL;
c6dbd2
+unsigned long int DSOLOCAL remote_rules_timeout = NOT_SET;
c6dbd2
+
c6dbd2
 
c6dbd2
 int DSOLOCAL status_engine_state = STATUS_ENGINE_DISABLED;
c6dbd2
 
c6dbd2
diff --git a/apache2/modsecurity.h b/apache2/modsecurity.h
c6dbd2
index f170034..d9de1f0 100644
c6dbd2
--- a/apache2/modsecurity.h
c6dbd2
+++ b/apache2/modsecurity.h
c6dbd2
@@ -150,6 +150,7 @@ extern DSOLOCAL msc_remote_rules_server *remote_rules_server;
c6dbd2
 #endif
c6dbd2
 extern DSOLOCAL int remote_rules_fail_action;
c6dbd2
 extern DSOLOCAL char *remote_rules_fail_message;
c6dbd2
+extern DSOLOCAL unsigned long int remote_rules_timeout;
c6dbd2
 
c6dbd2
 extern DSOLOCAL int status_engine_state;
c6dbd2
 
c6dbd2
diff --git a/apache2/msc_remote_rules.c b/apache2/msc_remote_rules.c
c6dbd2
index 8a6df9e..af437d1 100644
c6dbd2
--- a/apache2/msc_remote_rules.c
c6dbd2
+++ b/apache2/msc_remote_rules.c
c6dbd2
@@ -353,6 +353,11 @@ int msc_remote_download_content(apr_pool_t *mp, const char *uri, const char *key
c6dbd2
         /* We want Curl to return error in case there is an HTTP error code */
c6dbd2
         curl_easy_setopt(curl, CURLOPT_FAILONERROR, 1);
c6dbd2
 
c6dbd2
+        /* In case we want different timeout than a default one */
c6dbd2
+        if (remote_rules_timeout != NOT_SET){
c6dbd2
+            curl_easy_setopt(curl, CURLOPT_TIMEOUT, remote_rules_timeout);
c6dbd2
+        }
c6dbd2
+
c6dbd2
         res = curl_easy_perform(curl);
c6dbd2
 
c6dbd2
         if (res != CURLE_OK)