You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
51 lines
2.1 KiB
51 lines
2.1 KiB
# {{ ansible_managed }}
|
|
{% if httpd_mod_security | default(True) %}
|
|
|
|
SecRuleEngine Off
|
|
SecRequestBodyAccess Off
|
|
SecRule REQUEST_HEADERS:Content-Type "text/xml" \
|
|
"id:'200000',phase:1,t:none,t:lowercase,pass,nolog,ctl:requestBodyProcessor=XML"
|
|
SecRequestBodyLimit {{ httpd_mod_security_request_body_limit | default('13107200') }}
|
|
SecRequestBodyNoFilesLimit {{ httpd_mod_security_body_no_files_limit | default('131072') }}
|
|
SecRequestBodyInMemoryLimit {{ httpd_mod_security_in_memory_limit | default('131072') }}
|
|
SecRequestBodyLimitAction Reject
|
|
SecRule REQBODY_ERROR "!@eq 0" \
|
|
"id:'200001', phase:2,t:none,log,deny,status:400,msg:'Failed to parse request body.',logdata:'%{reqbody_error_msg}',severity:2"
|
|
SecRule MULTIPART_STRICT_ERROR "!@eq 0" \
|
|
"id:'200002',phase:2,t:none,log,deny,status:44,msg:'Multipart request body \
|
|
failed strict validation: \
|
|
PE %{REQBODY_PROCESSOR_ERROR}, \
|
|
BQ %{MULTIPART_BOUNDARY_QUOTED}, \
|
|
BW %{MULTIPART_BOUNDARY_WHITESPACE}, \
|
|
DB %{MULTIPART_DATA_BEFORE}, \
|
|
DA %{MULTIPART_DATA_AFTER}, \
|
|
HF %{MULTIPART_HEADER_FOLDING}, \
|
|
LF %{MULTIPART_LF_LINE}, \
|
|
SM %{MULTIPART_MISSING_SEMICOLON}, \
|
|
IQ %{MULTIPART_INVALID_QUOTING}, \
|
|
IP %{MULTIPART_INVALID_PART}, \
|
|
IH %{MULTIPART_INVALID_HEADER_FOLDING}, \
|
|
FL %{MULTIPART_FILE_LIMIT_EXCEEDED}'"
|
|
|
|
SecRule MULTIPART_UNMATCHED_BOUNDARY "!@eq 0" \
|
|
"id:'200003',phase:2,t:none,log,deny,status:44,msg:'Multipart parser detected a possible unmatched boundary.'"
|
|
|
|
SecPcreMatchLimit 1000
|
|
SecPcreMatchLimitRecursion 1000
|
|
|
|
SecRule TX:/^MSC_/ "!@streq 0" \
|
|
"id:'200004',phase:2,t:none,deny,msg:'ModSecurity internal error flagged: %{MATCHED_VAR_NAME}'"
|
|
|
|
SecResponseBodyAccess Off
|
|
SecDebugLog /var/log/httpd/modsec_debug.log
|
|
SecDebugLogLevel {{ httpd_mod_security_debug_level | default(0) }}
|
|
SecAuditEngine RelevantOnly
|
|
SecAuditLogRelevantStatus "^(?:5|4(?!04))"
|
|
SecAuditLogParts ABIJDEFHZ
|
|
SecAuditLogType Serial
|
|
SecAuditLog /var/log/httpd/modsec_audit.log
|
|
SecArgumentSeparator &
|
|
SecCookieFormat 0
|
|
SecTmpDir /var/lib/mod_security
|
|
SecDataDir /var/lib/mod_security
|
|
{% endif %}
|
|
|