{"api_version":"1","generated_at":"2026-04-17T00:19:46+00:00","cve":"CVE-2023-40180","urls":{"html":"https://cve.report/CVE-2023-40180","api":"https://cve.report/api/cve/CVE-2023-40180.json","docs":"https://cve.report/api","cve_org":"https://www.cve.org/CVERecord?id=CVE-2023-40180","nvd":"https://nvd.nist.gov/vuln/detail/CVE-2023-40180"},"summary":{"title":"CVE-2023-40180","description":"silverstripe-graphql is a package which serves Silverstripe data in GraphQL representations. An attacker could use a recursive graphql query to execute a Distributed Denial of Service attack (DDOS attack) against a website. This mostly affects websites with publicly exposed graphql schemas. If your Silverstripe CMS project does not expose a public facing graphql schema, a user account is required to trigger the DDOS attack. If your site is hosted behind a content delivery network (CDN), such as Imperva or CloudFlare, this may further mitigate the risk. This issue has been addressed in versions 3.8.2, 4.1.3, 4.2.5, 4.3.4, and 5.0.3. Users are advised to upgrade. There are no known workarounds for this vulnerability.","state":"PUBLIC","assigner":"security-advisories@github.com","published_at":"2023-10-16 19:15:00","updated_at":"2023-10-23 14:21:00"},"problem_types":["CWE-400"],"metrics":[],"references":[{"url":"https://docs.silverstripe.org/en/developer_guides/graphql/security_and_best_practices/recursive_or_complex_queries","name":"https://docs.silverstripe.org/en/developer_guides/graphql/security_and_best_practices/recursive_or_complex_queries","refsource":"MISC","tags":[],"title":"Recursive or complex queries | Silverstripe CMS Documentation","mime":"text/html","httpstatus":"200","archivestatus":"404"},{"url":"https://www.silverstripe.org/download/security-releases/CVE-2023-40180","name":"https://www.silverstripe.org/download/security-releases/CVE-2023-40180","refsource":"MISC","tags":[],"title":"CVE-2023-40180 - DDOS Vulnerability on GraphQL due to lack of protection against recursive queries » Silverstripe CMS","mime":"text/html","httpstatus":"200","archivestatus":"404"},{"url":"https://github.com/silverstripe/silverstripe-graphql/security/advisories/GHSA-v23w-pppm-jh66","name":"https://github.com/silverstripe/silverstripe-graphql/security/advisories/GHSA-v23w-pppm-jh66","refsource":"MISC","tags":[],"title":"DDOS Vulnerability on GraphQL due to lack of protection against recursive queries · Advisory · silverstripe/silverstripe-graphql · GitHub","mime":"text/html","httpstatus":"200","archivestatus":"404"},{"url":"https://github.com/silverstripe/silverstripe-graphql/commit/f6d5976ec4608e51184b0db1ee5b9e9a99d2501c","name":"https://github.com/silverstripe/silverstripe-graphql/commit/f6d5976ec4608e51184b0db1ee5b9e9a99d2501c","refsource":"MISC","tags":[],"title":"[CVE-2023-40180] Add protection against recursive queries (#558) · silverstripe/silverstripe-graphql@f6d5976 · GitHub","mime":"text/html","httpstatus":"200","archivestatus":"404"},{"url":"https://github.com/silverstripe/silverstripe-graphql/tree/3.8#recursive-or-complex-queries","name":"https://github.com/silverstripe/silverstripe-graphql/tree/3.8#recursive-or-complex-queries","refsource":"MISC","tags":[],"title":"GitHub - silverstripe/silverstripe-graphql at 3.8","mime":"text/html","httpstatus":"200","archivestatus":"404"},{"url":"https://www.cve.org/CVERecord?id=CVE-2023-40180","name":"CVE Program record","refsource":"CVE.ORG","tags":["canonical"]},{"url":"https://nvd.nist.gov/vuln/detail/CVE-2023-40180","name":"NVD vulnerability detail","refsource":"NVD","tags":["canonical","analysis"]}],"affected":[],"timeline":[],"solutions":[],"workarounds":[],"exploits":[],"credits":[],"nvd_cpes":[{"cve_year":"2023","cve_id":"40180","vulnerable":"1","versionEndIncluding":"","cpe1":"cpe","cpe2":"2.3","cpe3":"a","cpe4":"silverstripe","cpe5":"graphql","cpe6":"*","cpe7":"*","cpe8":"*","cpe9":"*","cpe10":"*","cpe11":"*","cpe12":"*","cpe13":"*"}],"vendor_comments":[],"enrichments":{"kev":null,"epss":null,"legacy_qids":[{"cve":"CVE-2023-40180","qid":"995586","title":"PHP (Composer) Security Update for silverstripe/graphql (GHSA-v23w-pppm-jh66)"}]},"source_records":{"cve_program":{"data_version":"4.0","data_type":"CVE","data_format":"MITRE","CVE_data_meta":{"ID":"CVE-2023-40180","ASSIGNER":"security-advisories@github.com","STATE":"PUBLIC"},"description":{"description_data":[{"lang":"eng","value":" silverstripe-graphql is a package which serves Silverstripe data in GraphQL representations. An attacker could use a recursive graphql query to execute a Distributed Denial of Service attack (DDOS attack) against a website. This mostly affects websites with publicly exposed graphql schemas. If your Silverstripe CMS project does not expose a public facing graphql schema, a user account is required to trigger the DDOS attack. If your site is hosted behind a content delivery network (CDN), such as Imperva or CloudFlare, this may further mitigate the risk. This issue has been addressed in versions 3.8.2, 4.1.3, 4.2.5, 4.3.4, and 5.0.3. Users are advised to upgrade. There are no known workarounds for this vulnerability."}]},"problemtype":{"problemtype_data":[{"description":[{"lang":"eng","value":"CWE-400: Uncontrolled Resource Consumption","cweId":"CWE-400"}]}]},"affects":{"vendor":{"vendor_data":[{"vendor_name":"silverstripe","product":{"product_data":[{"product_name":"silverstripe-graphql","version":{"version_data":[{"version_affected":"=","version_value":">= 3.0.0, < 3.8.1"},{"version_affected":"=","version_value":">= 4.0.0, < 4.1.3"},{"version_affected":"=","version_value":">= 4.2.0, < 4.2.5"},{"version_affected":"=","version_value":">= 4.3.0, < 4.3.4"},{"version_affected":"=","version_value":">= 5.0.0, < 5.0.3"}]}}]}}]}},"references":{"reference_data":[{"url":"https://github.com/silverstripe/silverstripe-graphql/security/advisories/GHSA-v23w-pppm-jh66","refsource":"MISC","name":"https://github.com/silverstripe/silverstripe-graphql/security/advisories/GHSA-v23w-pppm-jh66"},{"url":"https://github.com/silverstripe/silverstripe-graphql/commit/f6d5976ec4608e51184b0db1ee5b9e9a99d2501c","refsource":"MISC","name":"https://github.com/silverstripe/silverstripe-graphql/commit/f6d5976ec4608e51184b0db1ee5b9e9a99d2501c"},{"url":"https://docs.silverstripe.org/en/developer_guides/graphql/security_and_best_practices/recursive_or_complex_queries","refsource":"MISC","name":"https://docs.silverstripe.org/en/developer_guides/graphql/security_and_best_practices/recursive_or_complex_queries"},{"url":"https://github.com/silverstripe/silverstripe-graphql/tree/3.8#recursive-or-complex-queries","refsource":"MISC","name":"https://github.com/silverstripe/silverstripe-graphql/tree/3.8#recursive-or-complex-queries"},{"url":"https://www.silverstripe.org/download/security-releases/CVE-2023-40180","refsource":"MISC","name":"https://www.silverstripe.org/download/security-releases/CVE-2023-40180"}]},"source":{"advisory":"GHSA-v23w-pppm-jh66","discovery":"UNKNOWN"},"impact":{"cvss":[{"attackComplexity":"LOW","attackVector":"NETWORK","availabilityImpact":"HIGH","baseScore":7.5,"baseSeverity":"HIGH","confidentialityImpact":"NONE","integrityImpact":"NONE","privilegesRequired":"NONE","scope":"UNCHANGED","userInteraction":"NONE","vectorString":"CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:H","version":"3.1"}]}},"nvd":{"publishedDate":"2023-10-16 19:15:00","lastModifiedDate":"2023-10-23 14:21:00","problem_types":["CWE-400"],"metrics":{"baseMetricV3":{"cvssV3":{"version":"3.1","vectorString":"CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:H","attackVector":"NETWORK","attackComplexity":"LOW","privilegesRequired":"NONE","userInteraction":"NONE","scope":"UNCHANGED","confidentialityImpact":"NONE","integrityImpact":"NONE","availabilityImpact":"HIGH","baseScore":7.5,"baseSeverity":"HIGH"},"exploitabilityScore":3.9,"impactScore":3.6}},"configurations":{"CVE_data_version":"4.0","nodes":[{"operator":"OR","children":[],"cpe_match":[{"vulnerable":true,"cpe23Uri":"cpe:2.3:a:silverstripe:graphql:*:*:*:*:*:*:*:*","versionStartIncluding":"3.0.0","versionEndExcluding":"3.8.2","cpe_name":[]},{"vulnerable":true,"cpe23Uri":"cpe:2.3:a:silverstripe:graphql:*:*:*:*:*:*:*:*","versionStartIncluding":"4.0.0","versionEndExcluding":"4.1.3","cpe_name":[]},{"vulnerable":true,"cpe23Uri":"cpe:2.3:a:silverstripe:graphql:*:*:*:*:*:*:*:*","versionStartIncluding":"4.2.0","versionEndExcluding":"4.2.5","cpe_name":[]},{"vulnerable":true,"cpe23Uri":"cpe:2.3:a:silverstripe:graphql:*:*:*:*:*:*:*:*","versionStartIncluding":"4.3.0","versionEndExcluding":"4.3.4","cpe_name":[]},{"vulnerable":true,"cpe23Uri":"cpe:2.3:a:silverstripe:graphql:*:*:*:*:*:*:*:*","versionStartIncluding":"5.0.0","versionEndExcluding":"5.0.3","cpe_name":[]}]}]}},"legacy_mitre":{"record":null,"notes":[]}}}