Vulnerability DatabaseGHSA-95wr-3f2v-v2wh

GHSA-95wr-3f2v-v2wh
PHP vulnerability analysis and mitigation

Summary

The resource-js endpoint in Craft CMS allows unauthenticated requests to proxy remote JavaScript resources. When trustedHosts is not explicitly restricted (default configuration), the application trusts the client-supplied Host header. This allows an attacker to control the derived baseUrl, which is used in prefix validation inside actionResourceJs(). By supplying a malicious Host header, the attacker can make the server issue arbitrary HTTP requests, leading to Server-Side Request Forgery (SSRF).

Details

The vulnerability exists in AppController::actionResourceJs(). The function validates that the url parameter starts with assetManager->baseUrl. However, baseUrl is derived from the current request host. If trustedHosts is not configured, the Host header is fully attacker-controlled. Attack chain:

  1. Attacker sends request with controlled Host header.
  2. Application derives baseUrl from the malicious Host.
  3. url parameter is required to start with this baseUrl.
  4. Validation passes.
  5. Guzzle performs a server-side HTTP request to the attacker-controlled host.
  6. SSRF occurs.This does not rely on string parsing bypass. It relies on Host header trust.

PoC (safe reproduction steps)

Environment:

  • Craft CMS 5.9.12
  • Default configuration (no trustedHosts restriction)
  • Docker deployment
  1. Start a listener inside the container: python3 -m http.server 9999
  2. Send a request to resource-js with a controlled Host header.
  3. Observe that the internal listener receives a request (OOB confirmation).

SourceNVD

Related PHP vulnerabilities:

CVE ID

Severity

Score

Technologies

Component name

CISA KEV exploit

Has fix

Published date

GHSA-pq8p-wc4f-vg7jHIGH8.8
  • PHPPHP
  • wwbn/avideo
NoNoApr 14, 2026
GHSA-m7r8-6q9j-m2hcMEDIUM5.9
  • PHPPHP
  • wwbn/avideo
NoNoApr 14, 2026
GHSA-95wr-3f2v-v2whMEDIUM5.5
  • PHPPHP
  • craftcms/cms
NoYesApr 14, 2026
GHSA-3m9m-24vh-39wxMEDIUM5.5
  • PHPPHP
  • craftcms/cms
NoYesApr 14, 2026
GHSA-jq2f-59pj-p3m3MEDIUM5.3
  • PHPPHP
  • craftcms/cms
NoYesApr 14, 2026

Free Vulnerability Assessment

Benchmark your Cloud Security Posture

Evaluate your cloud security practices across 9 security domains to benchmark your risk level and identify gaps in your defenses.

Request assessment

Get a personalized demo

Ready to see Wiz in action?

"Best User Experience I have ever seen, provides full visibility to cloud workloads."
David EstlickCISO
"Wiz provides a single pane of glass to see what is going on in our cloud environments."
Adam FletcherChief Security Officer
"We know that if Wiz identifies something as critical, it actually is."
Greg PoniatowskiHead of Threat and Vulnerability Management