-
Notifications
You must be signed in to change notification settings - Fork 1.6k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Feature Request (v2): Add support for macro expansion for ipMatch operator #3332
Comments
Macro expansion should probably be allowed everywhere and consistent between all SecLang implementations. |
This is the list of operators (in mod_security2) which support macros: @rsub Adding the macro expansion to each operator (one by one) is not difficult, but I'm not sure all operators need that feature. Perhaps we should decide what other operators need that, and implement that in one PR. Add macro expansion in general seems very difficult and I'm afraid we should re-organize the code structure - I'm not sure it's worth it. List of operators which do not support macro expansion: @unconditionalMatch Please make a comment which operators need the macro expansion feature. |
For the operators:
Is it correct that these operators all pre-compile search trees and similar data structures? Does that mean that adding macro expansion to these operators would involve a big performance penalty? It feels similar to macro expansion with |
Hi @RedXanadu, thanks for the answer!
Sorry, what trees and data structures you think about?
Yes, using macros causes a small performance degradation. But if the operator does not use macros, then the expansion code won't run - I mean if we add the macro expansion, then that will be an option/chance to use that, the expansion flow will evaluated only if the operator's argument begins with I think your mentioned case ( Hope this helped to clarify the behavior. Just one question: why did you mark the first two operators with an |
airween, I think the |
But (I'm sure you guys know that) @ipMatchFromFile and @pmFromFile operators handle their arguments as files. What's the use case here? You pass a macro as argument, then operator evaluates it at every transaction: expand the macro, look up the value (which must be a file...), open it and process the content? Or put macro's into files? |
Feature
libModSecurity3 supports the use of transaction collection variables as an value when using the ipMatch operator, this isn't the case for ModSecurity2.
For example. these rules work on libModSecurity3 but not on ModSecurity2:
Another issue I encountered was you can't use semicolons within an setvar action, this issue happens on both engines and makes referencing IPv6 addresses via a variable unusable. I'm not sure if I'm doing something wrong here but I feel like this should work.
Use Case:
This is yet another issue with the CRS Nextcloud plugin, this feature in particular is needed to disable certain rules for the server itself. There's no way to know what the server's IP might be in advance, so this needs to be an configuration option. For now this is documented in the readme but it does complicate the installation process and requires end users to manually update the rule if changes are ever made to it.
Maybe there's a better way to do what I'm trying to do, but this feels like the easiest for the end user as all they'd need to change is a single variable in the plugin config file.
The text was updated successfully, but these errors were encountered: