forked from istio/envoy
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
http: header map security fixes for duplicate headers (istio#197)
Previously header matching did not match on all headers for non-inline headers. This patch changes the default behavior to always logically match on all headers. Multiple individual headers will be logically concatenated with ',' similar to what is done with inline headers. This makes the behavior effectively consistent. This behavior can be temporary reverted by setting the runtime value "envoy.reloadable_features.header_match_on_all_headers" to "false". Targeted fixes have been additionally performed on the following extensions which make them consider all duplicate headers by default as a comma concatenated list: 1) Any extension using CEL matching on headers. 2) The header to metadata filter. 3) The JWT filter. 4) The Lua filter. Like primary header matching used in routing, RBAC, etc. this behavior can be disabled by setting the runtime value "envoy.reloadable_features.header_match_on_all_headers" to false. Finally, the setCopy() header map API previously only set the first header in the case of duplicate non-inline headers. setCopy() now behaves similiarly to the other set*() APIs and replaces all found headers with a single value. This may have had security implications in the extauth filter which uses this API. This behavior can be disabled by setting the runtime value "envoy.reloadable_features.http_set_copy_replace_all_headers" to false. Fixes https://github.com/envoyproxy/envoy-setec/issues/188 Signed-off-by: Matt Klein <mklein@lyft.com>
- Loading branch information
1 parent
41e65e2
commit 2c60632
Showing
29 changed files
with
503 additions
and
78 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,27 @@ | ||
1.15.1 (TBD) | ||
============ | ||
|
||
Changes | ||
------- | ||
* http: fixed CVE-2020-25017. Previously header matching did not match on all headers for non-inline | ||
headers. This patch changes the default behavior to always logically match on all headers. | ||
Multiple individual headers will be logically concatenated with ',' similar to what is done with | ||
inline headers. This makes the behavior effectively consistent. This behavior can be temporary | ||
reverted by setting the runtime value "envoy.reloadable_features.header_match_on_all_headers" to | ||
"false". | ||
|
||
Targeted fixes have been additionally performed on the following extensions which make them | ||
consider all duplicate headers by default as a comma concatenated list: | ||
|
||
1. Any extension using CEL matching on headers. | ||
2. The header to metadata filter. | ||
3. The JWT filter. | ||
4. The Lua filter. | ||
|
||
Like primary header matching used in routing, RBAC, etc. this behavior can be disabled by setting | ||
the runtime value "envoy.reloadable_features.header_match_on_all_headers" to false. | ||
* http: The setCopy() header map API previously only set the first header in the case of duplicate | ||
non-inline headers. setCopy() now behaves similarly to the other set*() APIs and replaces all found | ||
headers with a single value. This may have had security implications in the extauth filter which | ||
uses this API. This behavior can be disabled by setting the runtime value | ||
"envoy.reloadable_features.http_set_copy_replace_all_headers" to false. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -7,6 +7,7 @@ Version history | |
:titlesonly: | ||
|
||
current | ||
v1.15.1 | ||
v1.15.0 | ||
v1.14.3 | ||
v1.14.2 | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.