Ecosyste.ms: Advisories
An open API service providing security vulnerability metadata for many open source software ecosystems.
Security Advisories: GSA_kwCzR0hTQS04Mjc0LWg1anAtOTd2cs4AAtr1
Diactoros before 2.11.1 vulnerable to HTTP Host Header Attack
Impact
Applications that use Diactoros, and are either not behind a proxy, or can be accessed via untrusted proxies, can potentially have the host, protocol, and/or port of a Laminas\Diactoros\Uri
instance associated with the incoming server request modified to reflect values from X-Forwarded-*
headers. Such changes can potentially lead to XSS attacks (if a fully-qualified URL is used in links) and/or URL poisoning.
Patches
Any version after 2.11.0.
Starting in laminas/laminas-diactoros 2.11.1, we have added Laminas\Diactoros\ServerRequestFilter\FilterServerRequestInterface
, which defines the single method __invoke(Psr\Http\Message\ServerRequestInterface $request): Psr\Http\Message\ServerRequestInterface
. Filters implementing this interface allow modifying and returning a generated ServerRequest
.
The primary use case of the interface is to allow modifying the generated URI based on the presence of headers such as X-Forwarded-Host
. When operating behind a reverse proxy, the Host
header is often rewritten to the name of the node to which the request is being forwarded, and an X-Forwarded-Host
header is generated with the original Host
value to allow the server to determine the original host the request was intended for. (We have always examined the X-Forwarded-Proto
header; as of Diactoros 2.11.1, we also examine the X-Forwarded-Port
header.) To accommodate this use case, we created Laminas\Diactoros\ServerRequestFilter\FilterUsingXForwardedHeaders.
Due to potential security issues, it is generally best to only accept these headers if you trust the reverse proxy that has initiated the request.
(This value is found in $_SERVER['REMOTE_ADDR']
, which is present as $request->getServerParams()['REMOTE_ADDR']
within PSR-7 implementations.) FilterUsingXForwardedHeaders
provides named constructors to allow you to trust these headers from any source (which has been the default behavior of Diactoros since the beginning), or to specify specific IP addresses or CIDR subnets to trust, along with which headers are trusted.
Laminas\Diactoros\ServerRequestFactory::fromGlobals()
was updated to accept a FilterServerRequestInterface
as an additional, optional argument. Since the X-Forwarded-*
headers do have valid use cases, particularly in clustered environments using a load balancer, to prevent backwards compatibility breaks, if no filter is provided, we generate an instance via FilterUsingXForwardedHeaders::trustReservedSubnets()
, which generates an instance marked to trust only proxies on private subnets.
Workarounds
Infrastructure or DevOps can configure web servers to reject X-Forwarded-*
headers at the web server level.
Users of laminas/laminas-diactoros can make use of the Laminas\Diactoros\RequestFilter\RequestFilterInterface
functionality in order to either (a) disable usage of the X-Forwarded-*
headers entirely, (b) opt-in to it, or (c) opt-in to the usage for configured proxy servers.
References
For more information
If you have any questions or comments about this advisory:
- Open an issue in laminas/laminas-diactoros
- Email us
JSON: https://advisories.ecosyste.ms/api/v1/advisories/GSA_kwCzR0hTQS04Mjc0LWg1anAtOTd2cs4AAtr1
Source: GitHub Advisory Database
Origin: Unspecified
Severity: Moderate
Classification: General
Published: almost 2 years ago
Updated: over 1 year ago
CVSS Score: 6.1
CVSS vector: CVSS:3.1/AV:N/AC:L/PR:N/UI:R/S:C/C:L/I:L/A:N
Identifiers: GHSA-8274-h5jp-97vr, CVE-2022-31109
References:
- https://github.com/laminas/laminas-diactoros/security/advisories/GHSA-8274-h5jp-97vr
- https://github.com/laminas/laminas-diactoros/commit/25b11d422c2e5dad868f68619888763b30f91e2d
- https://github.com/laminas/laminas-diactoros/releases/tag/2.11.1
- https://nvd.nist.gov/vuln/detail/CVE-2022-31109
- https://github.com/FriendsOfPHP/security-advisories/blob/master/laminas/laminas-diactoros/CVE-2022-31109.yaml
- https://github.com/advisories/GHSA-8274-h5jp-97vr
- https://portswigger.net/web-security/host-header
Blast Radius: 25.5
Affected Packages
packagist:laminas/laminas-diactoros
Dependent packages: 825Dependent repositories: 15,115
Downloads: 63,831,141 total
Affected Version Ranges: < 2.11.1
Fixed in: 2.11.1
All affected versions: 1.0.0, 1.0.1, 1.0.2, 1.0.3, 1.0.4, 1.0.5, 1.1.0, 1.1.1, 1.1.2, 1.1.3, 1.1.4, 1.2.0, 1.2.1, 1.3.0, 1.3.1, 1.3.2, 1.3.3, 1.3.4, 1.3.5, 1.3.6, 1.3.7, 1.3.8, 1.3.9, 1.3.10, 1.3.11, 1.4.0, 1.4.1, 1.5.0, 1.6.0, 1.6.1, 1.7.0, 1.7.1, 1.7.2, 1.8.0, 1.8.1, 1.8.2, 1.8.3, 1.8.4, 1.8.5, 1.8.6, 1.8.7, 2.0.0, 2.0.1, 2.0.2, 2.0.3, 2.1.0, 2.1.1, 2.1.2, 2.1.3, 2.1.4, 2.1.5, 2.2.0, 2.2.1, 2.2.2, 2.2.3, 2.3.0, 2.3.1, 2.3.2, 2.4.0, 2.4.1, 2.5.0, 2.5.1, 2.6.0, 2.7.0, 2.8.0, 2.9.0, 2.9.1, 2.9.2, 2.10.0, 2.11.0
All unaffected versions: 2.11.1, 2.11.2, 2.11.3, 2.12.0, 2.13.0, 2.14.0, 2.15.0, 2.16.0, 2.17.0, 2.18.0, 2.18.1, 2.19.0, 2.19.1, 2.20.0, 2.20.1, 2.21.0, 2.21.1, 2.22.0, 2.22.1, 2.23.0, 2.23.1, 2.24.0, 2.24.1, 2.24.2, 2.25.0, 2.25.1, 2.25.2, 2.26.0, 3.0.0, 3.1.0, 3.2.0, 3.3.0, 3.3.1