About App Security
The App Security Add-on for F5 NGINX Controller ADC lets you protect your applications with a web applications firewall (WAF). The WAF protects your apps from a variety of application layer attacks such as cross-site scripting (XSS), SQL injection, and cookie poisoning, among others.
A WAF protects your web apps by filtering, monitoring, and blocking any malicious HTTP/S traffic traveling to the web application, and prevents any unauthorized data from leaving the app. It does this by adhering to a set of policies that help determine what traffic is malicious and what traffic is safe. Just as a proxy server acts as an intermediary to protect the identity of a client, a WAF operates in similar fashion but in the reverse—called a reverse proxy—acting as an intermediary that protects the web app server from a potentially malicious client.
To learn more about what a WAF is and how it works, check out the F5 DevCentral video: What is a Web Application Firewall?
App Security on NGINX Controller provides an app‑centric self‑service model to address the security needs of modern apps.
The App Security add-on uses the NGINX App Protect Web Application Firewall (F5 WAF for NGINX) enforcement engine on the data path (data plane). When you enable WAF on an app component using NGINX Controller, a security policy (sets of security controls and enforcement logic) is deployed and applied to configured NGINX App Protect instances that process traffic for the app component.
F5 WAF for NGINX inspects incoming traffic as specified in the Security Policy to identify potential threats. When malicious traffic is suspected or blocked, the NGINX Controller Analytics module logs security events and metrics. These are then included in the NGINX Controller Threat Visibility and Analytics reporting.
To learn more, read the Threat Visibility and Analytics blog post on nginx.com.
 
In NGINX Controller, the Security Policy contains an F5 WAF for NGINX policy. The F5 WAF for NGINX policy has security controls and settings in a declarative JSON format. The Security Policy defines the rules and settings for application traffic inspection, detection of malicious traffic, and handling violations when they occur. For more about creating, updating, or deleting Security Policies, see the Policies API Reference.
When enabling WAF to protect your Apps, you can either add your own custom Security Policy or use the default Security Policy.
A Security Strategy is a logical container for multiple Security Policies. In a Security Strategy, you can reference a Security Policy that represents a security risk profile. For example, you can map low- or high-risk security profiles to different Security Strategies as you deem fit for your Apps’ specific use case or organizational needs.
When you enable security on the App Component, you can specify the Security Strategy to protect it. You can use the same Security Strategy across multiple app components. The Security Policy referenced in the Security Strategy detects and protects against malicious traffic to the App Component.
- App Component references Security Strategy;
- Security Strategy references Security Policy.
For more about creating, updating, or deleting Security Policies, see the Strategies API Reference.
You can use a custom Security Strategy to protect your Apps, or you can use NGINX Controller’s default Security Strategy, which contains a pre-defined WAF policy.
The
/services/strategies/balanced_defaultendpoint was replaced by/security/strategies/balanced_defaultin NGINX Controller ADC v3.18.
- Specify the
StrategyRefsetting with/security/strategies/balanced_defaultinstead of/services/strategies/balanced_default.Refer to the AskF5 knowledge base article K02089505 for more information.