BigIP: Security Policies
This comprehensive blog post provides a detailed breakdown of configuring security policies in BIG-IP ASM, covering essential elements such as policy types, enforcement modes, learning modes, and signature accuracy settings, offering practical examples and explanations for each component.
This screen displays various configuration settings for creating a security policy in F5’s BIG-IP application delivery controller. Let’s break down each topic and its options:
1. Policy Name
- This field allows us to enter a name for the security policy we’re creating.
2. Description
- This optional field allows us to provide a brief description or notes about the policy.
3. Policy Type:
In our context, the “Security” option is selected, indicating that this policy will be a standalone security policy for inspecting and filtering traffic based on security rules and signatures. The “Parent” option would be used if we wanted to create a parent policy first, and then create child policies inheriting settings from the parent.
The “Policy Type” field has two options: “Security” and “Parent”. Here’s an explanation of what each option does, along with examples:
a. Security:
The “Security” option is used to create a security policy that inspects and filters network traffic based on predefined security rules and signatures. This type of policy is designed to protect against various threats such as SQL injection, cross-site scripting (XSS), buffer overflows, and other types of attacks.
Example: Let’s say we’re setting up a web application on the BIG-IP system. We would create a security policy with the “Security” type to inspect the incoming and outgoing traffic for potential threats. This policy would have rules and signatures that detect and block malicious payloads, prevent data leakage, and enforce security best practices.
b. Parent:
The “Parent” option is used to create a parent policy, which serves as a container or template for other child policies. A parent policy doesn’t have any specific security rules or configurations of its own. Instead, it acts as a centralized location to manage and inherit settings for child policies.
Example: Imagine we have multiple web applications running on different virtual servers, but we want to enforce a consistent set of security rules across all of them. We could create a parent policy with common security settings, and then create child policies for each virtual server that inherit those settings from the parent. This way, any changes made to the parent policy will automatically propagate to all child policies, ensuring a consistent security posture across our applications.
4. Learning
Policy building by whitelisting entities involves defining what types of requests are allowed. This approach focuses on listing specific entities such as file types, URLs, parameters, cookies, and redirection domains that are permitted, while blocking everything else.
Positive Security Model
The positive security model allows only known good requests and responses, blocking everything else.
Requests:
Allowed File Types:
- Example: Allow access to .php, .txt, .pdf, .jpg files.
- Restrict access to .exe, .ini files to prevent execution of potentially harmful scripts.
Users can upload .pdf and .jpg files but are restricted from uploading .exe files.
Allowed URLs:
- Example: Block access to administrative URLs like /admin/admin.php.
Users are prohibited from accessing /admin/admin.php to secure the admin panel.
Allowed Parameters:
- Example: Accept only untampered parameters in requests.
Ensure parameters like user IDs are not tampered with during transactions.
Responses:
Allowed Response Codes:
- Example: Allow 100, 200, 300 status codes.
- Send custom responses for 400 and 500 status codes to avoid revealing sensitive information.
Return custom error pages for 404 errors to avoid exposing server details.
Negative Security Model
The negative security model allows all traffic except known bad requests or traffic.
Requests:
RFC Compliance:
- Example: Ensure incoming requests comply with RFC standards such as HTTP 1.1, use of Host Header, and proper Content Types.
Verify that all incoming requests adhere to HTTP 1.1 standards.
Evasion Detection:
- Example: Detect if an attacker is hiding malicious scripts behind legitimate traffic.
Analyze traffic to detect and block evasive techniques used by attackers.
Attack Signatures:
- Example: Compare requests against a database of 4000 attack signatures.
Match incoming requests against known attack signatures to identify threats.
Responses:
Attack Signatures:
- Example: Check if responses contain any known attacks.
Inspect outgoing responses to ensure they do not contain malicious content.
Data Guard:
- Example: Mask sensitive information in responses.
Use data masking to protect sensitive information such as credit card numbers.
Whitelisting Entities:
Entity | Description |
---|---|
File Types | Specify allowed file types (e.g., .php, .txt, .pdf, .jpg). Block disallowed types (e.g., .exe, .ini). |
URLs | Restrict access to certain URLs (e.g., block /admin/admin.php). |
Parameters | Ensure only untampered parameters are accepted. |
Cookies | Learn and enforce only specified cookies. |
Redirection Domains | Whitelist specific domains for redirection. |
Policy building by false positive elimination focuses on refining security policies by eliminating false positives from attack signatures and other violations.
False Positive Elimination:
A legitimate request to a web application can also trigger violation.
Entity | Description |
---|---|
Attack Signatures | Continuously refine attack signatures to reduce false positives. |
Other Violations | Address and eliminate other policy violations to improve accuracy. |
5. Policy Templates
a. Rapid Deployment Policy (RDP)
Human Considerations | Security policy considerations |
---|---|
Requires minimal configuration | Relies on negative security |
Fast setup | No application entity learning |
Administrator does not need much prior knowledge about the application | Can mitigate some WAF requirements for payment/privacy data (PCI, etc.) |
Learning suggestions must be accepted manually | Can mask data in logs and GUI |
Detects evasion techniques | |
Low resource requirements | |
Option to refine and react |
Use Cases:
- Administrator primarily interested in negative security checks
- Administrator has limited or no access to application developers
- Administrator wants minimal maintenance effort after initial deployment
- Administrator wants to avoid creation of explicit file type, URL, and parameter entities
Let’s explore available options:
Option | Value | Explanation |
---|---|---|
Application Language | UTF-8 | UTF-8 is a character encoding standard that supports most of the world’s languages. It is used to ensure proper handling of non-ASCII characters in the application traffic. |
Learning mode | Manual | In manual mode, the system does not automatically learn and add new security signatures. All signatures must be manually configured. |
Enforcement mode | Transparent | In transparent mode, the policy monitors and logs violations but does not actively block or modify the traffic. This mode is suitable for initial deployment and testing. |
Signature Sets | Generic Detection Signatures | The policy uses a set of generic signatures provided by F5 to detect common security threats. |
Signature Staging | Enabled | New signatures are staged (tested) before being enforced in production. This helps prevent false positives. |
Learn New Cookies | Selective | The system learns and tracks only specified cookies, not all cookies encountered. |
Learn New File Types | Never (whitelist only) | The system does not learn or track new file types. Only whitelisted file types are allowed. |
Learn Host Names | Disabled | The system does not learn or track host names. |
Learn New Parameters | Never (whitelist only) | The system does not learn or track new parameters. Only whitelisted parameters are allowed. |
Learn New Redirection Domains | Never (whitelist only) | The system does not learn or track new redirection domains. Only whitelisted domains are allowed. |
Server Technology Detection | Disabled | The system does not attempt to detect the server technology (e.g., Apache, IIS) used by the application. |
Detect Login Pages | Disabled | The system does not attempt to detect and learn login pages. |
Learn New HTTP URLs | Never (whitelist only) | The system does not learn or track new HTTP URLs. Only whitelisted URLs are allowed. |
Learn New WebSocket URLs | Never (whitelist only) | The system does not learn or track new WebSocket URLs. Only whitelisted WebSocket URLs are allowed. |
b. Passive Deployment Policy (PDP)
Use Cases:
- A network switch mirrors all ingress and egress traffic and sends it to the SPAN port on BIG-IP
- Administrator does not want F5 Adv. WAF to enforce any rules
- Administrator does want event logging and reporting
- Administrator wants to evaluate F5 Adv. WAF with no risk and quick deployment
Let’s explore available options:
Option | Value | Explanation |
---|---|---|
Application Language | Auto-detect | The system automatically detects the application language (character encoding) based on the traffic. |
Learning mode | Automatic | The system automatically learns and adds new security signatures based on the traffic it sees. |
Enforcement mode | Transparent | In transparent mode, the policy monitors and logs violations but does not actively block or modify the traffic. |
Signature Sets | Generic Detection Signatures | The policy uses a set of generic signatures provided by F5 to detect common security threats. |
Signature Staging | Enabled | New signatures are staged (tested) before being enforced in production. |
Learn New Cookies | Selective | The system learns and tracks only specified cookies, not all cookies encountered. |
Learn New File Types | Compact | The system learns and tracks common file types but excludes uncommon or potentially malicious file types. |
Learn Host Names | Enabled | The system learns and tracks host names encountered in the traffic. |
Learn New Parameters | Compact | The system learns and tracks common parameters but excludes uncommon or potentially malicious parameters. |
Learn New Redirection Domains | Always | The system learns and tracks all new redirection domains encountered in the traffic. |
Server Technology Detection | Enabled | The system attempts to detect the server technology (e.g., Apache, IIS) used by the application. |
Detect Login Pages | Disabled | The system does not attempt to detect and learn login pages. |
Learn New HTTP URLs | Compact | The system learns and tracks common HTTP URLs but excludes uncommon or potentially malicious URLs. |
Learn New WebSocket URLs | Always | The system learns and tracks all new WebSocket URLs encountered in the traffic. |
c. Fundamental
Human Considerations | Security policy considerations |
---|---|
Minimal user intervention | Some negative security (attack signatures, HTTP compliance Low level of positive security (file types & parameters, cookies) |
Doesn’t required app knowledge | Automatically updates attack signatures |
Full manual control always available | Needs to see a lot of diverse traffic before policy is mature |
Some application knowledge is helpful | Policy in blocking mode by default |
Use Cases:
- Administrator wants a level of application awareness
- Administrator wants a low level of positive security (adding file types, parameters, and cookies)
- Administrator wants F5 Adv. WAF to control policy building automatically
Let’s explore available options:
Option | Value | Explanation |
---|---|---|
Application Language | Auto-detect | The system automatically detects the application language (character encoding) based on the traffic. |
Learning mode | Automatic | The system automatically learns and adds new security signatures based on the traffic it sees. |
Enforcement mode | Blocking | In blocking mode, the policy actively blocks or modifies traffic deemed a threat based on the security rules and signatures. |
Signature Sets | Generic Detection Signatures | The policy uses a set of generic signatures provided by F5 to detect common security threats. |
Signature Staging | Enabled | New signatures are staged (tested) before being enforced in production. |
Learn New Cookies | Selective | The system learns and tracks only specified cookies, not all cookies encountered. |
Learn New File Types | Compact | The system learns and tracks common file types but excludes uncommon or potentially malicious file types. |
Learn Host Names | Enabled | The system learns and tracks host names encountered in the traffic. |
Learn New Parameters | Selective | The system learns and tracks only specified parameters, not all parameters encountered. |
Learn New Redirection Domains | Always | The system learns and tracks all new redirection domains encountered in the traffic. |
Server Technology Detection | Enabled | The system attempts to detect the server technology (e.g., Apache, IIS) used by the application. |
Detect Login Pages | Disabled | The system does not attempt to detect and learn login pages. |
Learn New HTTP URLs | Never (whitelist only) | The system does not learn or track new HTTP URLs. Only whitelisted URLs are allowed. |
Learn New WebSocket URLs | Never (whitelist only) | The system does not learn or track new WebSocket URLs. Only whitelisted WebSocket URLs are allowed. |
d. Comprehensive
Human Considerations | Security policy considerations |
---|---|
Minimal user intervention | Some negative security (attack signatures, HTTP compliance Higher level of positive security (file types & parameters, cookies) |
Doesn’t required app knowledge | Automatically updates attack signatures |
Full manual control always available | Needs to see a lot of diverse traffic before policy is mature |
Some application knowledge is helpful | Policy is blocking mode by default |
Use Cases:
- Administrator does not want full implementation of negative security
- Administrator wants a higher level of positive security (adding file types, URLs, parameters, and cookies)
- Administrator wants F5 Adv. WAF to control policy building automatically
Let’s explore available options:
Option | Value | Explanation |
---|---|---|
Application Language | Auto-detect | The system automatically detects the application language (character encoding) based on the traffic. |
Learning mode | Automatic | The system automatically learns and adds new security signatures based on the traffic it sees. |
Enforcement mode | Blocking | In blocking mode, the policy actively blocks or modifies traffic deemed a threat based on the security rules and signatures. |
Signature Sets | Generic Detection Signatures | The policy uses a set of generic signatures provided by F5 to detect common security threats. |
Signature Staging | Enabled | New signatures are staged (tested) before being enforced in production. |
Learn New Cookies | Selective | The system learns and tracks only specified cookies, not all cookies encountered. |
Learn New File Types | Compact | The system learns and tracks common file types but excludes uncommon or potentially malicious file types. |
Learn Host Names | Enabled | The system learns and tracks host names encountered in the traffic. |
Learn New Parameters | Compact | The system learns and tracks common parameters but excludes uncommon or potentially malicious parameters. |
Learn New Redirection Domains | Always | The system learns and tracks all new redirection domains encountered in the traffic. |
Server Technology Detection | Enabled | The system attempts to detect the server technology (e.g., Apache, IIS) used by the application. |
Detect Login Pages | Enabled | The system attempts to detect and learn login pages. |
Learn New HTTP URLs | Compact | The system learns and tracks common HTTP URLs but excludes uncommon or potentially malicious URLs. |
Learn New WebSocket URLs | Always | The system learns and tracks all new WebSocket URLs encountered in the traffic. |
e. API Security
Let’s explore available options:
Option | Value | Explanation |
---|---|---|
Application Language | UTF-8 | UTF-8 is a character encoding standard that supports most of the world’s languages. It is used to ensure proper handling of non-ASCII characters in the application traffic. |
Learning mode | Manual | In manual mode, the system does not automatically learn and add new security signatures. All signatures must be manually configured. |
Enforcement mode | Blocking | In blocking mode, the policy actively blocks or modifies traffic deemed a threat based on the security rules and signatures. |
Signature Sets | Generic Detection Signatures | The policy uses a set of generic signatures provided by F5 to detect common security threats. |
Signature Staging | Enabled | New signatures are staged (tested) before being enforced in production. |
Learn New Cookies | Never (whitelist only) | The system does not learn or track new cookies. Only whitelisted cookies are allowed. |
Learn New File Types | Never (whitelist only) | The system does not learn or track new file types. Only whitelisted file types are allowed. |
Learn Host Names | Disabled | The system does not learn or track host names. |
Learn New Parameters | Never (whitelist only) | The system does not learn or track new parameters |
6. Virtual Server
- This option allows us to associate the policy with a specific virtual server on the BIG-IP system. In this case, “None” is selected, meaning the policy is not yet associated with any virtual server.
7. Application Language
- The “Unicode (utf-8)” option is selected, which specifies the character encoding for the application traffic that the policy will handle.
8. Enforcement Mode
- This setting determines how the policy will handle traffic. The “Blocking” option is selected, which means that the policy will actively block traffic deemed a threat based on the policy rules.
a. Transparent
In transparent mode, the security policy monitors and logs violations but does not actively block or modify the traffic. This mode is typically used for initial deployment, testing, and fine-tuning the policy. It allows us to assess the policy’s effectiveness and identify potential false positives before enforcing it in blocking mode.
b. Blocking
In blocking mode, the security policy actively blocks or modifies traffic deemed a threat based on the configured security rules and signatures. This mode provides a more robust security posture by preventing potential attacks from reaching the application. However, it can also cause legitimate traffic to be blocked if the policy is not properly configured or tuned.
9. Policy Building Learning Mode
- Specifies how the system learns and adapts during the policy building process.
a. Automatic
The system automatically learns and adds new security signatures based on the traffic it sees. This mode is suitable for environments where the application’s behavior is well-understood, and the system can reliably identify and add relevant signatures.
Human Considerations | Security policy considerations |
---|---|
Minimal user intervention | Automatically adjusts policy as application changes |
Doesn’t required app knowledge | Automatically updates attack signatures |
Full manual control always available | Needs to see a lot of diverse traffic before policy is mature |
Use Cases:
- Multiple applications of varying complexity
- Some applications are constantly changing
- Limited staff members and skills in analysic of learning suggestions
b. Fully Automatic
This is an advanced mode of automatic learning. In fully automatic mode, the system not only learns and adds new signatures but also enforces them without manual intervention. This mode is typically used in highly dynamic environments where the application’s behavior changes frequently, and manual intervention for signature updates is not feasible.
c. Manual
In manual mode, the system does not automatically learn or add new signatures. All signatures must be manually configured and updated by the administrator. This mode is suitable for environments where the application’s behavior is well-defined and tightly controlled, and the administrator prefers complete control over the security policy.
Human Considerations | Security policy considerations |
---|---|
Easy to understand how F5 AWAF works | Nothing happens automatically when handling violations |
Forces you to sort out false positives and attacks | Can be configured to automatically update attack signatures |
Requires a bit more application knowledge | |
Deployment can be time consuming | |
Requires maintenance if application changes |
Use Cases:
- Manageable number of file types, URLs, parameters
- Experienced BigIP WAF administrators
- Fewer policies to manage
- It is possible to communicate with application developers
d. Disabled
In this mode, the system does not perform any automatic learning or signature updates. This mode is typically used for testing or troubleshooting purposes when we want to isolate the security policy from any automatic changes.
10. Auto-Added Signature Accuracy
- This setting controls the level of accuracy required for automatically added signatures. “Medium” is selected, which includes signatures with high and medium accuracy levels.
a. High
Only signatures with a high accuracy level (low likelihood of false positives) will be automatically added.
b. Medium (also includes signatures with high accuracy)
Signatures with both high and medium accuracy levels will be automatically added.
c. Low (also includes signatures with high and medium accuracy)
Signatures with high, medium, and low accuracy levels will be automatically added.
- By setting a higher accuracy level, we can reduce the risk of false positives but may miss some legitimate threats. By setting a lower accuracy level, we increase the likelihood of catching more threats but also increase the risk of false positives.
11. Trusted IP Addresses
- This field allows us to specify IP addresses that should be trusted and not inspected by the security policy.
12. Policy Builder Learning Speed
- Specifies the speed at which the system learns and adds new signatures when the learning mode is set to automatic or fully automatic.
a. Fast
The system learns and adds new signatures quickly, but this may consume more system resources and increase the risk of false positives.
b. Medium
The system learns and adds new signatures at a moderate pace, balancing learning speed with resource usage and accuracy.
c. Slow
The system learns and adds new signatures slowly, which may reduce the risk of false positives but also delay the addition of legitimate signatures.
13. Signature Staging
- Controls the deployment of newly added signatures.
a. Enabled
When signature staging is enabled, newly added signatures (either manually or automatically) are first staged (tested) in a non-enforcing mode. This allows us to assess the impact of the new signatures and identify potential false positives before enforcing them in production. Signature staging helps prevent legitimate traffic from being blocked due to misconfigured signatures.
b. Disabled
When signature staging is disabled, newly added signatures are immediately enforced in the production environment without any staging or testing period. This mode is typically used in environments where the security policy is well-tuned, and the risk of false positives is low.
- Signature staging is generally recommended as a best practice to ensure a smooth and controlled deployment of new security signatures, minimizing the risk of unintended traffic disruptions.
Policy Deployment Workflow
Here’s a step-by-step guide to deploying a basic security policy:
- Enter Name of Policy: Provide a unique name for the policy.
- Select Policy Type:
- Standalone Policy: Directly attach to virtual servers.
- Parent Policy: Use as a template and inherit it in child policies.
- Select Policy Template:
- Rapid: Fewer security checks, quick setup.
- Fundamental: More checks compared to rapid, suitable for moderate security needs.
- Comprehensive: Most security checks, suitable for high-security environments.
- Note: Templates can be customized or changed. Application-ready templates are available for specific platforms like Joomla, WordPress, etc.
Deployment:
When deploying a combination of positive and negative security models, we consider the following factors:
- Protection Priorities: Determine what protection is most important for your applications.
- Number of Security Policies: Assess how many policies are needed based on the complexity and number of applications.
- Time Constraints: Consider how much time is available for policy implementation and tuning.
- Application Changes: Evaluate how frequently applications change and how that impacts policy management.
- Application Complexity: Determine the complexity of applications to decide on the level of security required.
- Number of Applications: Consider the total number of applications that need protection.
Word Quiz
Correct := 0 | Wrong := 0
Question?
Fill the Answer
Correct:= 0 | Wrong:= 0
Question
Comments
comments powered by DisqusRelated Posts
BurpSuite: Part 1
Discover BurpSuite, a powerful tool for web application security testing, and learn about its features, use cases, and an open-source alternative called OWASP ZAP.
Read MoreDeploying to Cloudflare
If you are a beginner frontend developer, this is a goldmine for you. Host your website projects for free in cloudflare pages easily and shine infront of your competition in recruitments.
Read MoreBigIP: Guided Web Application Security Config
This comprehensive blog post provides a detailed breakdown of configuring security policies in BIG-IP ASM, covering essential elements such as policy types, enforcement modes, learning modes, and signature accuracy settings. It offers practical examples and explanations for each component, helping you enhance the security of your web applications.
Read More