Convert Figma logo to code with AI

owasp-modsecurity logoModSecurity

ModSecurity is an open source, cross platform web application firewall (WAF) engine for Apache, IIS and Nginx. It has a robust event-based programming language which provides protection from a range of attacks against web applications and allows for HTTP traffic monitoring, logging and real-time analysis.

8,368
1,621
8,368
232

Top Related Projects

ModSecurity is an open source, cross platform web application firewall (WAF) engine for Apache, IIS and Nginx. It has a robust event-based programming language which provides protection from a range of attacks against web applications and allows for HTTP traffic monitoring, logging and real-time analysis.

OWASP CRS (Official Repository)

4,803

NAXSI is an open-source, high performance, low rules maintenance WAF for NGINX

High-performance WAF built on the OpenResty stack

OWASP ModSecurity Core Rule Set (CRS) Project (Official Repository)

Quick Overview

ModSecurity is an open-source, cross-platform web application firewall (WAF) engine. It provides protection against various web application attacks and can be used as a standalone application or as a module for popular web servers like Apache, Nginx, and IIS.

Pros

  • Highly customizable and flexible rule set
  • Supports multiple web servers and platforms
  • Active community and regular updates
  • Extensive logging and monitoring capabilities

Cons

  • Can be complex to configure and maintain
  • May introduce performance overhead if not properly tuned
  • False positives can occur, requiring careful rule management
  • Learning curve for writing custom rules

Code Examples

  1. Basic rule to block SQL injection attempts:
SecRule ARGS "@detectSQLi" \
    "id:1000,\
    phase:2,\
    block,\
    msg:'SQL Injection Attempt Detected',\
    logdata:'Matched Data: %{MATCHED_VAR} found within %{MATCHED_VAR_NAME}',\
    severity:'CRITICAL'"
  1. Rule to prevent XSS attacks:
SecRule REQUEST_COOKIES|!REQUEST_COOKIES:/__utm/|REQUEST_COOKIES_NAMES|ARGS_NAMES|ARGS|XML:/* "@detectXSS" \
    "id:941110,\
    phase:2,\
    block,\
    t:none,t:utf8toUnicode,t:urlDecodeUni,t:htmlEntityDecode,t:jsDecode,t:cssDecode,t:removeNulls,\
    msg:'XSS Attack Detected',\
    logdata:'Matched Data: %{MATCHED_VAR} found within %{MATCHED_VAR_NAME}',\
    severity:'CRITICAL'"
  1. Rule to limit file upload size:
SecRule FILES_SIZES "@gt 1000000" \
    "id:2000,\
    phase:2,\
    block,\
    msg:'File upload too large',\
    logdata:'File size: %{MATCHED_VAR} bytes',\
    severity:'WARNING'"

Getting Started

  1. Install ModSecurity for your web server (e.g., Apache, Nginx)
  2. Configure ModSecurity in your web server configuration file
  3. Enable the OWASP Core Rule Set (CRS) or create custom rules
  4. Test your configuration and adjust rules as needed

Example Apache configuration:

<IfModule security2_module>
    SecRuleEngine On
    SecRequestBodyAccess On
    SecRule REQUEST_HEADERS:Content-Type "text/xml" \
         "id:'200000',phase:1,t:none,t:lowercase,pass,nolog,ctl:requestBodyProcessor=XML"
    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 ARGS "@detectSQLi" \
        "id:'200004',phase:2,t:none,log,deny,status:403,msg:'SQL Injection Attempt'"
    Include /etc/modsecurity/owasp-crs/crs-setup.conf
    Include /etc/modsecurity/owasp-crs/rules/*.conf
</IfModule>

Restart your web server after configuration changes.

Competitor Comparisons

ModSecurity is an open source, cross platform web application firewall (WAF) engine for Apache, IIS and Nginx. It has a robust event-based programming language which provides protection from a range of attacks against web applications and allows for HTTP traffic monitoring, logging and real-time analysis.

Pros of ModSecurity

  • More mature and widely adopted project
  • Extensive documentation and community support
  • Broader compatibility with various web servers

Cons of ModSecurity

  • Larger codebase, potentially more complex to maintain
  • May have higher resource requirements
  • Steeper learning curve for newcomers

Code Comparison

ModSecurity:

SecRule REQUEST_HEADERS:User-Agent "nikto" \
    "id:1,\
    phase:1,\
    t:lowercase,\
    block,\
    msg:'Nikto Scan Detected'"

ModSecurity>:

SecRule REQUEST_HEADERS:User-Agent "@contains nikto" \
    "id:1,\
    phase:1,\
    t:lowercase,\
    deny,\
    log,\
    msg:'Nikto Scan Detected'"

The code snippets show similar rule structures, with minor differences in syntax and action keywords. ModSecurity> uses the @contains operator and deny action, while ModSecurity uses a direct string match and block action. Both achieve the same goal of detecting and blocking Nikto scans.

ModSecurity is the original project, offering a robust and well-established web application firewall solution. It benefits from years of development and a large user base. ModSecurity>, on the other hand, appears to be a fork or related project, potentially offering some improvements or alternative features. However, without more specific information about ModSecurity>, it's challenging to provide a more detailed comparison of its unique attributes or advantages over the original ModSecurity project.

OWASP CRS (Official Repository)

Pros of coreruleset

  • Focused specifically on web application security rules
  • Regularly updated with new rules for emerging threats
  • Easier to customize and extend with additional rules

Cons of coreruleset

  • Requires ModSecurity or compatible engine to function
  • May generate false positives, requiring tuning
  • Limited to HTTP/HTTPS protection

Code Comparison

ModSecurity (rule example):

SecRule REQUEST_HEADERS:User-Agent "nikto" \
    "id:1,\
    phase:1,\
    t:lowercase,\
    block,\
    msg:'Nikto Scan Detected'"

coreruleset (rule example):

SecRule REQUEST_HEADERS:User-Agent "@rx (?:nikto|sqlmap|dirbuster)" \
    "id:920260,\
    phase:1,\
    block,\
    t:none,t:lowercase,\
    msg:'Suspicious User Agent',\
    logdata:'%{MATCHED_VAR}'"

The coreruleset example shows a more comprehensive rule covering multiple suspicious user agents, while ModSecurity's example is simpler but less extensive. coreruleset rules often include additional metadata and are designed to work together as a cohesive ruleset.

4,803

NAXSI is an open-source, high performance, low rules maintenance WAF for NGINX

Pros of Naxsi

  • Lightweight and designed specifically for Nginx, offering better performance
  • Simpler configuration and easier to set up for basic use cases
  • Uses a whitelist approach, potentially reducing false positives

Cons of Naxsi

  • Less comprehensive rule set compared to ModSecurity
  • Limited to Nginx, not as versatile across different web servers
  • Smaller community and fewer third-party resources available

Code Comparison

ModSecurity rule example:

SecRule REQUEST_HEADERS:User-Agent "nikto" \
    "id:1,phase:1,t:lowercase,deny,log,msg:'Nikto Scan Detected'"

Naxsi rule example:

MainRule "str:nikto" "msg:Nikto Scan Detected" "mz:$HEADERS_VAR:User-Agent" "s:$UWA:8" id:1;

Both examples show rules to detect and block requests from the Nikto web vulnerability scanner. ModSecurity uses a more verbose syntax with explicit actions, while Naxsi employs a more compact format with predefined actions. ModSecurity offers more granular control over rule behavior, whereas Naxsi focuses on simplicity and ease of use.

High-performance WAF built on the OpenResty stack

Pros of lua-resty-waf

  • Written in Lua, which is lightweight and fast, potentially offering better performance
  • Designed specifically for OpenResty, allowing seamless integration with NGINX
  • More flexible and customizable due to its modular architecture

Cons of lua-resty-waf

  • Smaller community and less widespread adoption compared to ModSecurity
  • Fewer pre-built rulesets available, requiring more manual configuration
  • Less comprehensive documentation and support resources

Code Comparison

ModSecurity (C++):

SecRule REQUEST_HEADERS:User-Agent "nikto" \
    "id:1,\
    phase:1,\
    t:lowercase,\
    block,\
    msg:'Nikto Scan Detected'"

lua-resty-waf (Lua):

waf:exec(function()
    if ngx.var.http_user_agent:lower():find("nikto") then
        ngx.exit(ngx.HTTP_FORBIDDEN)
    end
end)

Both examples show a simple rule to detect and block requests with "nikto" in the User-Agent header. ModSecurity uses a declarative syntax, while lua-resty-waf employs a more programmatic approach, leveraging Lua's flexibility.

OWASP ModSecurity Core Rule Set (CRS) Project (Official Repository)

Pros of owasp-modsecurity-crs

  • Provides a comprehensive set of rules for web application security
  • Regularly updated with new rules to address emerging threats
  • Easily customizable to fit specific application needs

Cons of owasp-modsecurity-crs

  • Requires ModSecurity as a dependency to function
  • May generate false positives, requiring fine-tuning
  • Can impact performance if not optimized properly

Code Comparison

ModSecurity (core functionality):

SecRule REQUEST_HEADERS:User-Agent "nikto" \
    "id:1,\
    phase:1,\
    t:lowercase,\
    block,\
    msg:'Nikto Scan Detected'"

owasp-modsecurity-crs (rule example):

SecRule REQUEST_FILENAME|ARGS_NAMES|ARGS|XML:/* "@rx (?i:(?:m(?:s(?:ysaccessobjects|ysaces|ysobjects)|db)|adodb|jet)\.(dbo\.|sys)?objects)" \
    "id:942180,\
    phase:2,\
    block,\
    capture,\
    t:none,t:urlDecodeUni,\
    msg:'Detecting MSSQL code execution and information gathering attempts'"

The ModSecurity repository focuses on the core Web Application Firewall (WAF) engine, while owasp-modsecurity-crs provides a set of rules to be used with ModSecurity. The core engine offers flexibility and customization, whereas the CRS provides ready-to-use rules for common web application threats.

Convert Figma logo designs to code with AI

Visual Copilot

Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.

Try Visual Copilot

README

Quality Assurance Build Status

Libmodsecurity is one component of the ModSecurity v3 project. The library codebase serves as an interface to ModSecurity Connectors taking in web traffic and applying traditional ModSecurity processing. In general, it provides the capability to load/interpret rules written in the ModSecurity SecRules format and apply them to HTTP content provided by your application via Connectors.

If you are looking for ModSecurity for Apache (aka ModSecurity v2.x), it is still under maintenance and available: here.

What is the difference between this project and the old ModSecurity (v2.x.x)?

  • All Apache dependencies have been removed
  • Higher performance
  • New features
  • New architecture

Libmodsecurity is a complete rewrite of the ModSecurity platform. When it was first devised the ModSecurity project started as just an Apache module. Over time the project has been extended, due to popular demand, to support other platforms including (but not limited to) Nginx and IIS. In order to provide for the growing demand for additional platform support, it has became necessary to remove the Apache dependencies underlying this project, making it more platform independent.

As a result of this goal we have rearchitected Libmodsecurity such that it is no longer dependent on the Apache web server (both at compilation and during runtime). One side effect of this is that across all platforms users can expect increased performance. Additionally, we have taken this opportunity to lay the groundwork for some new features that users have been long seeking. For example we are looking to natively support auditlogs in the JSON format, along with a host of other functionality in future versions.

It is no longer just a module.

The 'ModSecurity' branch no longer contains the traditional module logic (for Nginx, Apache, and IIS) that has traditionally been packaged all together. Instead, this branch only contains the library portion (libmodsecurity) for this project. This library is consumed by what we have termed 'Connectors' these connectors will interface with your webserver and provide the library with a common format that it understands. Each of these connectors is maintained as a separate GitHub project. For instance, the Nginx connector is supplied by the ModSecurity-nginx project (https://github.com/owasp-modsecurity/ModSecurity-nginx).

Keeping these connectors separated allows each project to have different release cycles, issues and development trees. Additionally, it means that when you install ModSecurity v3 you only get exactly what you need, no extras you won't be using.

Compilation

Before starting the compilation process, make sure that you have all the dependencies in place. Read the subsection “Dependencies” for further information.

After the compilation make sure that there are no issues on your build/platform. We strongly recommend the utilization of the unit tests and regression tests. These test utilities are located under the subfolder ‘tests’.

As a dynamic library, don’t forget that libmodsecurity must be installed to a location (folder) where you OS will be looking for dynamic libraries.

Unix (Linux, MacOS, FreeBSD, …)

On unix the project uses autotools to help the compilation process. Please note that if you are working with git, don't forget to initialize and update the submodules. Here's a quick how-to:

$ git clone --recursive https://github.com/owasp-modsecurity/ModSecurity ModSecurity
$ cd ModSecurity

You can then start the build process:

$ ./build.sh
$ ./configure
$ make
$ sudo make install

Details on distribution specific builds can be found in our Wiki: Compilation Recipes

Windows

Windows build information can be found here.

Dependencies

This library is written in C++ using the C++17 standards. It also uses Flex and Yacc to produce the “Sec Rules Language” parser. Other, mandatory dependencies include YAJL, as ModSecurity uses JSON for producing logs and its testing framework, libpcre (not yet mandatory) for processing regular expressions in SecRules, and libXML2 (not yet mandatory) which is used for parsing XML requests.

All others dependencies are related to operators specified within SecRules or configuration directives and may not be required for compilation. A short list of such dependencies is as follows:

  • libinjection is needed for the operator @detectXSS and @detectSQL
  • curl is needed for the directive SecRemoteRules.

If those libraries are missing ModSecurity will be compiled without the support for the operator @detectXSS and the configuration directive SecRemoteRules.

Library documentation

The library documentation is written within the code in Doxygen format. To generate this documentation, please use the doxygen utility with the provided configuration file, “doxygen.cfg”, located with the "doc/" subfolder. This will generate HTML formatted documentation including usage examples.

Library utilization

The library provides a C++ and C interface. Some resources are currently only available via the C++ interface, for instance, the capability to create custom logging mechanism (see the regression test to check for how those logging mechanism works). The objective is to have both APIs (C, C++) providing the same functionality, if you find an aspect of the API that is missing via a particular interface, please open an issue.

Inside the subfolder examples, there are simple examples on how to use the API. Below some are illustrated:

Simple example using C++

using ModSecurity::ModSecurity;
using ModSecurity::Rules;
using ModSecurity::Transaction;

ModSecurity *modsec;
ModSecurity::Rules *rules;

modsec = new ModSecurity();

rules = new Rules();

rules->loadFromUri(rules_file);

Transaction *modsecTransaction = new Transaction(modsec, rules);

modsecTransaction->processConnection("127.0.0.1");
if (modsecTransaction->intervention()) {
   std::cout << "There is an intervention" << std::endl;
}

Simple example using C

#include "modsecurity/modsecurity.h"
#include "modsecurity/transaction.h"


char main_rule_uri[] = "basic_rules.conf";

int main (int argc, char **argv)
{
    ModSecurity *modsec = NULL;
    Transaction *transaction = NULL;
    Rules *rules = NULL;

    modsec = msc_init();

    rules = msc_create_rules_set();
    msc_rules_add_file(rules, main_rule_uri);

    transaction = msc_new_transaction(modsec, rules);

    msc_process_connection(transaction, "127.0.0.1");
    msc_process_uri(transaction, "http://www.modsecurity.org/test?key1=value1&key2=value2&key3=value3&test=args&test=test");
    msc_process_request_headers(transaction);
    msc_process_request_body(transaction);
    msc_process_response_headers(transaction);
    msc_process_response_body(transaction);

    return 0;
}

Contributing

You are more than welcome to contribute to this project and look forward to growing the community around this new version of ModSecurity. Areas of interest include: New functionalities, fixes, bug report, support for beginning users, or anything that you are willing to help with.

Providing patches

We prefer to have your patch within the GitHub infrastructure to facilitate our review work, and our Q.A. integration. GitHub provides excellent documentation on how to perform “Pull Requests”, more information available here: https://help.github.com/articles/using-pull-requests/

Please respect the coding style. Pull requests can include various commits, so provide one fix or one piece of functionality per commit. Please do not change anything outside the scope of your target work (e.g. coding style in a function that you have passed by). For further information about the coding style used in this project, please check: https://www.chromium.org/blink/coding-style

Provides explanative commit messages. Your first line should give the highlights of your patch, 3rd and on give a more detailed explanation/technical details about your patch. Patch explanation is valuable during the review process.

Don’t know where to start?

Within our code there are various items marked as TODO or FIXME that may need your attention. Check the list of items by performing a grep:

$ cd /path/to/modsecurity-nginx
$ egrep -Rin "TODO|FIXME" -R *

A TODO list is also available as part of the Doxygen documentation.

Testing your patch

Along with the manual testing, we strongly recommend you to use the our regression tests and unit tests. If you have implemented an operator, don’t forget to create unit tests for it. If you implement anything else, it is encouraged that you develop complimentary regression tests for it.

The regression test and unit test utilities are native and do not demand any external tool or script, although you need to fetch the test cases from other repositories, as they are shared with other versions of ModSecurity, those others repositories git submodules. To fetch the submodules repository and run the utilities, follow the commands listed below:

$ cd /path/to/your/ModSecurity
$ git submodule foreach git pull
$ cd test
$ ./regression-tests
$ ./unit-tests

Debugging

Before start the debugging process, make sure of where your bug is. The problem could be on your connector or in libmodsecurity. In order to identify where the bug is, it is recommended that you develop a regression test that mimics the scenario where the bug is happening. If the bug is reproducible with the regression-test utility, then it will be far simpler to debug and ensure that it never occurs again. On Linux it is recommended that anyone undertaking debugging utilize gdb and/or valgrind as needed.

During the configuration/compilation time, you may want to disable the compiler optimization making your “back traces” populated with readable data. Use the CFLAGS to disable the compilation optimization parameters:

$ export CFLAGS="-g -O0"
$ ./build.sh
$ ./configure --enable-assertions=yes
$ make
$ sudo make install

"Assertions allow us to document assumptions and to spot violations early in the development process. What is more, assertions allow us to spot violations with a minimum of effort." https://dl.acm.org/doi/pdf/10.1145/240964.240969

It is recommended to use assertions where applicable, and to enable them with '--enable-assertions=yes' during the testing and debugging workflow.

Benchmarking

The source tree includes a Benchmark tool that can help measure library performance. The tool is located in the test/benchmark/ directory. The build process also creates the binary here, so you will have the tool after the compilation is finished.

To run, just type:

cd test/benchmark
$ ./benchmark
Doing 1000000 transactions...

You can also pass a lower value:

$ ./benchmark 1000
Doing 1000 transactions...

To measure the time:

$ time ./benchmark 1000
Doing 1000 transactions...

real	0m0.351s
user	0m0.337s
sys	0m0.022s

This is very fast because the benchmark uses the minimal modsecurity.conf.default configuration, which doesn't include too many rules:

$ cat basic_rules.conf

Include "../../modsecurity.conf-recommended"

To measure with real rules, run one of the download scripts in the same directory:

$ ./download-owasp-v3-rules.sh
Cloning into 'owasp-v3'...
remote: Enumerating objects: 33007, done.
remote: Counting objects: 100% (2581/2581), done.
remote: Compressing objects: 100% (907/907), done.
remote: Total 33007 (delta 2151), reused 2004 (delta 1638), pack-reused 30426
Receiving objects: 100% (33007/33007), 9.02 MiB | 16.21 MiB/s, done.
Resolving deltas: 100% (25927/25927), done.
Switched to a new branch 'tag3.0.2'
/path/to/ModSecurity/test/benchmark
Done.

$ cat basic_rules.conf

Include "../../modsecurity.conf-recommended"

Include "owasp-v3/crs-setup.conf.example"
Include "owasp-v3/rules/*.conf"

Now the command will give much higher value.

How the benchmark works

The tool is a straightforward wrapper application that utilizes the library. It creates a ModSecurity instance and a RuleSet instance, then runs a loop based on the specified number. Within this loop, it creates a Transaction object to emulate real HTTP transactions.

Each transaction is an HTTP/1.1 GET request with some GET parameters. Common headers are added, followed by the response headers and an XML body. Between phases, the tool checks whether an intervention has occurred. All transactions are created with the same data.

Note that the tool does not call the last phase (logging).

Please remember to reset basic_rules.conf if you want to try with a different ruleset.

Reporting Issues

If you are facing a configuration issue or something is not working as you expected to be, please use the ModSecurity user’s mailing list. Issues on GitHub are also welcomed, but we prefer to have user ask questions on the mailing list first so that you can reach an entire community. Also don’t forget to look for existing issues before open a new one.

If you are going to open a new issue on GitHub, don’t forget to tell us the version of your libmodsecurity and the version of a specific connector if there is one.

Security issue

Please do not make public any security issue. Contact us at: modsecurity@owasp.org reporting the issue. Once the problem is fixed your credit will be given.

Feature request

We are open to discussing any new feature request with the community via the mailing lists. You can alternativly, feel free to open GitHub issues requesting new features. Before opening a new issue, please check if there is one already opened on the same topic.

Bindings

The libModSecurity design allows the integration with bindings. There is an effort to avoid breaking API [binary] compatibility to make an easy integration with possible bindings. Currently, there are a few notable projects maintained by the community:

Packaging

Having our packages in distros on time is a desire that we have, so let us know if there is anything we can do to facilitate your work as a packager.

Sponsor Note

Development of ModSecurity is sponsored by Trustwave. Sponsorship will end July 1, 2024. Additional information can be found here https://www.trustwave.com/en-us/resources/security-resources/software-updates/end-of-sale-and-trustwave-support-for-modsecurity-web-application-firewall/