add mitigation for unsupported normalization in security best practice (#9917)

* add mitigation for unsupported normalization in security best practice

* address comments

* address comments

* Apply suggestions from code review

Co-authored-by: Justin Pettit <jdpettit@google.com>

* Apply suggestions from code review

Co-authored-by: Eric Van Norman <ericvn@us.ibm.com>

* address comments

Co-authored-by: Justin Pettit <jdpettit@google.com>
Co-authored-by: Eric Van Norman <ericvn@us.ibm.com>
This commit is contained in:
Yangmin Zhu 2021-06-24 08:02:02 -07:00 committed by GitHub
parent 26f2abac12
commit 9c2b9b9358
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 84 additions and 7 deletions

View File

@ -508,6 +508,7 @@ misconfiguration
misconfigurations misconfigurations
misconfigured misconfigured
misordered misordered
mitigations
Mitigations Mitigations
MongoDB MongoDB
mongodb mongodb

View File

@ -31,7 +31,9 @@ It takes effort to configure the correct authorization policies to best protect
It is important to understand the implications of these configurations as Istio cannot determine the proper authorization for all users. It is important to understand the implications of these configurations as Istio cannot determine the proper authorization for all users.
Please follow this section in its entirety. Please follow this section in its entirety.
### Apply default-deny authorization policies ### Safer Authorization Policy Patterns
#### Use default-deny patterns
We recommend you define your Istio authorization policies following the default-deny pattern to enhance your cluster's security posture. We recommend you define your Istio authorization policies following the default-deny pattern to enhance your cluster's security posture.
The default-deny authorization pattern means your system denies all requests by default, and you define the conditions in which the requests are allowed. The default-deny authorization pattern means your system denies all requests by default, and you define the conditions in which the requests are allowed.
@ -42,6 +44,52 @@ For example, in the [authorization for HTTP traffic task](/docs/tasks/security/a
the authorization policy named `allow-nothing` makes sure all traffic is denied by default. the authorization policy named `allow-nothing` makes sure all traffic is denied by default.
From there, other authorization policies allow traffic based on specific conditions. From there, other authorization policies allow traffic based on specific conditions.
#### Use `ALLOW-with-positive-matching` and `DENY-with-negative-match` patterns
Use the `ALLOW-with-positive-matching` or `DENY-with-negative-matching` patterns whenever possible. These authorization policy
patterns are safer because the worst result in the case of policy mismatch is an unexpected 403 rejection instead of
an authorization policy bypass.
The `ALLOW-with-positive-matching` pattern is to use the `ALLOW` action only with **positive** matching fields (e.g. `paths`, `values`)
and do not use any of the **negative** matching fields (e.g. `notPaths`, `notValues`).
The `DENY-with-negative-matching` pattern is to use the `DENY` action only with **negative** matching fields (e.g. `notPaths`, `notValues`)
and do not use any of the **positive** matching fields (e.g. `paths`, `values`).
For example, the authorization policy below uses the `ALLOW-with-positive-matching` pattern to allow requests to path `/public`:
{{< text yaml >}}
apiVersion: security.istio.io/v1beta1
kind: AuthorizationPolicy
metadata:
name: foo
spec:
action: ALLOW
rules:
- to:
- operation:
paths: ["/public"]
{{< /text >}}
The above policy explicitly lists the allowed path (`/public`). This means the request path must be exactly the same as
`/public` to allow the request. Any other requests will be rejected by default eliminating the risk
of unknown normalization behavior causing policy bypass.
The following is an example using the `DENY-with-negative-matching` pattern to achieve the same result:
{{< text yaml >}}
apiVersion: security.istio.io/v1beta1
kind: AuthorizationPolicy
metadata:
name: foo
spec:
action: DENY
rules:
- to:
- operation:
notPaths: ["/public"]
{{< /text >}}
### Customize your system on path normalization ### Customize your system on path normalization
Istio authorization policies can be based on the URL paths in the HTTP request. Istio authorization policies can be based on the URL paths in the HTTP request.
@ -131,13 +179,26 @@ apiVersion: v1
... ...
{{< /text >}} {{< /text >}}
### Less common normalization configurations ### Mitigation for unsupported normalization
#### Case Normalization This section describes various mitigations for unsupported normalization. These could be useful when you need a specific
normalization that is not supported by Istio.
Please make sure you understand the mitigation thoroughly and use it carefully as some mitigations rely on things that are
out the scope of Istio and also not supported by Istio.
#### Custom normalization logic
You can apply custom normalization logic using the WASM or Lua filter. It is recommended to use the WASM filter because
it's officially supported and also used by Istio. You could use the Lua filter for a quick proof-of-concept DEMO but we do
not recommend using the Lua filter in production because it is not supported by Istio.
##### Example custom normalization (case normalization)
In some environments, it may be useful to have paths in authorization policies compared in a case insensitive manner. In some environments, it may be useful to have paths in authorization policies compared in a case insensitive manner.
For example, treating `https://myurl/get` and `https://myurl/GeT` as equivalent. For example, treating `https://myurl/get` and `https://myurl/GeT` as equivalent.
In those cases, the `EnvoyFilter` shown below can be used.
In those cases, the `EnvoyFilter` shown below can be used to insert a Lua filter to normalize the path to lower case.
This filter will change both the path used for comparison and the path presented to the application. This filter will change both the path used for comparison and the path presented to the application.
{{< text syntax=yaml snip_id=ingress_case_insensitive_envoy_filter >}} {{< text syntax=yaml snip_id=ingress_case_insensitive_envoy_filter >}}
@ -155,10 +216,8 @@ spec:
filterChain: filterChain:
filter: filter:
name: "envoy.filters.network.http_connection_manager" name: "envoy.filters.network.http_connection_manager"
subFilter:
name: "envoy.filters.http.router"
patch: patch:
operation: INSERT_BEFORE operation: INSERT_FIRST
value: value:
name: envoy.lua name: envoy.lua
typed_config: typed_config:
@ -170,6 +229,23 @@ spec:
end end
{{< /text >}} {{< /text >}}
#### Specialized Web Application Firewall (WAF)
Many specialized Web Application Firewall (WAF) products provide additional normalization options. They can be deployed in
front of the Istio ingress gateway to normalize requests entering the mesh. The authorization policy will then be enforced
on the normalized requests. Please refer to your specific WAF product for configuring the normalization options.
#### Feature request to Istio
If you believe Istio should officially support a specific normalization, you can follow the [reporting a vulnerability](/docs/releases/security-vulnerabilities/#reporting-a-vulnerability)
page to send a feature request about the specific normalization to the Istio Product Security Work Group for initial evaluation.
Please do not open any issues in public without first contacting the Istio Product Security Work Group because the
issue might be considered a security vulnerability that needs to be fixed in private.
If the Istio Product Security Work Group evaluates the feature request as not a security vulnerability, an issue will
be opened in public for further discussions of the feature request.
## Understand traffic capture limitations ## Understand traffic capture limitations
The Istio sidecar works by capturing both inbound traffic and outbound traffic and directing them through the sidecar proxy. The Istio sidecar works by capturing both inbound traffic and outbound traffic and directing them through the sidecar proxy.