{ "data_version": "4.0", "data_type": "CVE", "data_format": "MITRE", "CVE_data_meta": { "ID": "CVE-2023-41317", "ASSIGNER": "security-advisories@github.com", "STATE": "PUBLIC" }, "description": { "description_data": [ { "lang": "eng", "value": "The Apollo Router is a configurable, high-performance graph router written in Rust to run a federated supergraph that uses Apollo Federation 2. Affected versions are subject to a Denial-of-Service (DoS) type vulnerability which causes the Router to panic and terminate when GraphQL Subscriptions are enabled. It can be triggered when **all of the following conditions are met**: 1. Running Apollo Router v1.28.0, v1.28.1 or v1.29.0 (\"impacted versions\"); **and** 2. The Supergraph schema provided to the Router (either via Apollo Uplink or explicitly via other configuration)\u00a0**has a `subscription` type** with root-fields defined; **and** 3. The YAML configuration provided to the Router **has subscriptions enabled** (they are _disabled_ by default), either by setting `enabled: true` _or_ by setting a valid `mode` within the `subscriptions` object (as seen in [subscriptions' documentation](https://www.apollographql.com/docs/router/executing-operations/subscription-support/#router-setup)); **and** 4. An [anonymous](https://spec.graphql.org/draft/#sec-Anonymous-Operation-Definitions) (i.e., un-named) `subscription` operation (e.g., `subscription { ... }`) is received by the Router If **all four** of these criteria are met, the impacted versions will panic and terminate. There is no data-privacy risk or sensitive-information exposure aspect to this vulnerability. This is fixed in Apollo Router v1.29.1. Users are advised to upgrade. Updating to v1.29.1 should be a clear and simple upgrade path for those running impacted versions. However, if Subscriptions are **not** necessary for your Graph \u2013 but are enabled via configuration \u2014 then disabling subscriptions is another option to mitigate the risk." } ] }, "problemtype": { "problemtype_data": [ { "description": [ { "lang": "eng", "value": "CWE-755: Improper Handling of Exceptional Conditions", "cweId": "CWE-755" } ] } ] }, "affects": { "vendor": { "vendor_data": [ { "vendor_name": "apollographql", "product": { "product_data": [ { "product_name": "router", "version": { "version_data": [ { "version_affected": "=", "version_value": ">= 1.28.0, < 1.29.1" } ] } } ] } } ] } }, "references": { "reference_data": [ { "url": "https://github.com/apollographql/router/security/advisories/GHSA-w8vq-3hf9-xppx", "refsource": "MISC", "name": "https://github.com/apollographql/router/security/advisories/GHSA-w8vq-3hf9-xppx" }, { "url": "https://github.com/apollographql/router/commit/b295c103dd86c57c848397d32e8094edfa8502aa", "refsource": "MISC", "name": "https://github.com/apollographql/router/commit/b295c103dd86c57c848397d32e8094edfa8502aa" }, { "url": "https://github.com/apollographql/router/releases/tag/v1.29.1", "refsource": "MISC", "name": "https://github.com/apollographql/router/releases/tag/v1.29.1" } ] }, "source": { "advisory": "GHSA-w8vq-3hf9-xppx", "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" } ] } }