GHSA-68jq-c3rv-pcrr

Suggest an improvement
Source
https://github.com/advisories/GHSA-68jq-c3rv-pcrr
Import Source
https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2026/04/GHSA-68jq-c3rv-pcrr/GHSA-68jq-c3rv-pcrr.json
JSON Data
https://api.osv.dev/v1/vulns/GHSA-68jq-c3rv-pcrr
Aliases
  • CVE-2026-40476
Published
2026-04-14T01:05:05Z
Modified
2026-05-05T16:05:13.632592Z
Severity
  • 6.9 (Medium) CVSS_V4 - CVSS:4.0/AV:N/AC:L/AT:N/PR:N/UI:N/VC:N/VI:N/VA:L/SC:N/SI:N/SA:N CVSS Calculator
Summary
graphql-php is affected by a Denial of Service via quadratic complexity in OverlappingFieldsCanBeMerged validation
Details

The OverlappingFieldsCanBeMerged validation rule exhibits quadratic time complexity when processing queries with many repeated fields sharing the same response name. An attacker can send a crafted query like { hello hello hello ... } with thousands of repeated fields, causing excessive CPU usage during validation before execution begins.

This is not mitigated by existing QueryDepth or QueryComplexity rules.

Observed impact (tested on v15.31.4): - 1000 fields: ~0.6s - 2000 fields: ~2.4s - 3000 fields: ~5.3s - 5000 fields: request timeout (>20s)

Root cause: collectConflictsWithin() performs O(n²) pairwise comparisons of all fields with the same response name. For identical repeated fields, every comparison returns "no conflict" but the quadratic iteration count causes resource exhaustion.

Fix: Deduplicate structurally identical fields before pairwise comparison, reducing the complexity from O(n²) to O(u²) where u is the number of unique field signatures (typically 1 for this attack pattern).

Credit: Ashwak N (ashwakn04@gmail.com)

Database specific
{
    "cwe_ids": [
        "CWE-407"
    ],
    "github_reviewed": true,
    "github_reviewed_at": "2026-04-14T01:05:05Z",
    "nvd_published_at": "2026-04-17T22:16:33Z",
    "severity": "MODERATE"
}
References

Affected packages

Packagist / webonyx/graphql-php

Package

Name
webonyx/graphql-php
Purl
pkg:composer/webonyx/graphql-php

Affected ranges

Type
ECOSYSTEM
Events
Introduced
0Unknown introduced version / All previous versions are affected
Fixed
15.31.5

Affected versions

v0.*
v0.1
v0.2
v0.3
v0.4
v0.5
v0.5.1
v0.5.2
v0.5.3
v0.5.4
v0.5.5
v0.5.6
v0.5.7
v0.5.8
v0.5.9
v0.6.0
v0.6.1
v0.6.2
v0.6.3
v0.6.4
v0.7.0
v0.7.1
v0.7.2
v0.8.0
v0.9.0
v0.9.1
v0.9.2
v0.9.3
v0.9.4
v0.9.5
v0.9.6
v0.9.7
v0.9.8
v0.9.9
v0.9.10
v0.9.11
v0.9.12
v0.9.13
v0.9.14
v0.10.0-rc1
v0.10.0
v0.10.1
v0.10.2
v0.11.0
v0.11.1
v0.11.2
v0.11.3
v0.11.4
v0.11.5
v0.11.6
v0.12.0
v0.12.1
v0.12.2
v0.12.3
v0.12.4
v0.12.5
v0.12.6
v0.13.0
v0.13.1
v0.13.2
v0.13.3
v0.13.4
v0.13.5
v0.13.6
v0.13.7
v0.13.8
v0.13.9
v14.*
v14.0.0
v14.0.1
v14.0.2
v14.1.0
v14.1.1
v14.2.0
v14.3.0
v14.4.0
v14.4.1
v14.5.0
v14.5.1
v14.6.0
v14.6.1
v14.6.2
v14.6.3
v14.6.4
v14.7.0
v14.8.0
v14.9.0
v14.11.0
v14.11.1
v14.11.2
v14.11.3
v14.11.4
v14.11.5
v14.11.6
v14.11.7
v14.11.8
v14.11.9
v14.11.10
14.*
14.10.0
v15.*
v15.0.0-alpha.1
v15.0.0-alpha.2
v15.0.0-beta.1
v15.0.0
v15.0.1
v15.0.2
v15.0.3
v15.1.0
v15.2.0
v15.2.1
v15.2.2
v15.2.3
v15.2.4
v15.2.5
v15.3.0
v15.3.1
v15.3.2
v15.4.0
v15.5.0
v15.5.1
v15.5.2
v15.5.3
v15.6.0
v15.6.1
v15.6.2
v15.6.3
v15.7.0
v15.8.0
v15.8.1
v15.9.0
v15.9.1
v15.10.0
v15.11.0
v15.11.1
v15.11.2
v15.12.0
v15.12.1
v15.12.2
v15.12.3
v15.12.4
v15.12.5
v15.13.0
v15.14.0
v15.14.1
v15.14.2
v15.14.3
v15.15.0
v15.16.0
v15.16.1
v15.17.0
v15.18.0
v15.18.1
v15.19.0
v15.19.1
v15.20.0
v15.20.1
v15.21.0
v15.21.1
v15.21.2
v15.21.3
v15.22.0
v15.22.1
v15.22.2
v15.22.3
v15.22.4
v15.23.0
v15.23.1
v15.24.0
v15.25.0
v15.25.1
v15.25.2
v15.26.0
v15.27.0
v15.27.1
v15.27.2
v15.28.0
v15.29.0
v15.29.1
v15.29.2
v15.29.3
v15.29.4
v15.30.0
v15.30.1
v15.30.2
v15.31.0
v15.31.1
v15.31.2
v15.31.3
v15.31.4

Database specific

source
"https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2026/04/GHSA-68jq-c3rv-pcrr/GHSA-68jq-c3rv-pcrr.json"
last_known_affected_version_range
"<= 15.31.4"