{"dataType":"CVE_RECORD","dataVersion":"5.1","cveMetadata":{"cveId":"CVE-2024-31205","assignerOrgId":"a0819718-46f1-4df5-94e2-005712e83aaa","state":"PUBLISHED","assignerShortName":"GitHub_M","dateReserved":"2024-03-29T14:16:31.899Z","datePublished":"2024-04-08T14:26:30.971Z","dateUpdated":"2024-08-02T01:46:04.600Z"},"containers":{"cna":{"title":"Saleor CSRF bypass in refreshToken mutation","problemTypes":[{"descriptions":[{"cweId":"CWE-352","lang":"en","description":"CWE-352: Cross-Site Request Forgery (CSRF)","type":"CWE"}]}],"metrics":[{"cvssV3_1":{"attackComplexity":"HIGH","attackVector":"NETWORK","availabilityImpact":"NONE","baseScore":4.2,"baseSeverity":"MEDIUM","confidentialityImpact":"LOW","integrityImpact":"LOW","privilegesRequired":"NONE","scope":"UNCHANGED","userInteraction":"REQUIRED","vectorString":"CVSS:3.1/AV:N/AC:H/PR:N/UI:R/S:U/C:L/I:L/A:N","version":"3.1"}}],"references":[{"name":"https://github.com/saleor/saleor/security/advisories/GHSA-ff69-fwjf-3c9w","tags":["x_refsource_CONFIRM"],"url":"https://github.com/saleor/saleor/security/advisories/GHSA-ff69-fwjf-3c9w"},{"name":"https://github.com/saleor/saleor/commit/36699c6f5c99590d24f46e3d5c5b1a3c2fd072e7","tags":["x_refsource_MISC"],"url":"https://github.com/saleor/saleor/commit/36699c6f5c99590d24f46e3d5c5b1a3c2fd072e7"}],"affected":[{"vendor":"saleor","product":"saleor","versions":[{"version":">= 3.10.0, < 3.14.64","status":"affected"},{"version":">= 3.15.0, < 3.15.39","status":"affected"},{"version":">= 3.16.0, < 3.16.39","status":"affected"},{"version":">= 3.17.0, < 3.17.35","status":"affected"},{"version":">= 3.18.0, < 3.18.31","status":"affected"},{"version":">= 3.19.0, < 3.19.19","status":"affected"}]}],"providerMetadata":{"orgId":"a0819718-46f1-4df5-94e2-005712e83aaa","shortName":"GitHub_M","dateUpdated":"2024-04-08T14:26:30.971Z"},"descriptions":[{"lang":"en","value":"Saleor is an e-commerce platform. Starting in version 3.10.0 and prior to versions 3.14.64, 3.15.39, 3.16.39, 3.17.35, 3.18.31, and 3.19.19, an attacker may bypass cross-set request forgery (CSRF) validation when calling refresh token mutation with empty string. When a user provides an empty string in `refreshToken` mutation, while the token persists in `JWT_REFRESH_TOKEN_COOKIE_NAME` cookie, application omits validation against CSRF token and returns valid access token. Versions 3.14.64, 3.15.39, 3.16.39, 3.17.35, 3.18.31, and 3.19.19 contain a patch for the issue. As a workaround, one may replace `saleor.graphql.account.mutations.authentication.refresh_token.py.get_refresh_token`. This will fix the issue, but be aware, that it returns `JWT_MISSING_TOKEN` instead of `JWT_INVALID_TOKEN`.\n"}],"source":{"advisory":"GHSA-ff69-fwjf-3c9w","discovery":"UNKNOWN"}},"adp":[{"title":"CISA ADP Vulnrichment","metrics":[{"other":{"type":"ssvc","content":{"id":"CVE-2024-31205","role":"CISA Coordinator","options":[{"Exploitation":"none"},{"Automatable":"no"},{"Technical Impact":"partial"}],"version":"2.0.3","timestamp":"2024-04-09T15:46:25.741486Z"}}}],"providerMetadata":{"orgId":"134c704f-9b21-4f2e-91b3-4a467353bcc0","shortName":"CISA-ADP","dateUpdated":"2024-06-04T17:37:18.826Z"}},{"providerMetadata":{"orgId":"af854a3a-2127-422b-91ae-364da2661108","shortName":"CVE","dateUpdated":"2024-08-02T01:46:04.600Z"},"title":"CVE Program Container","references":[{"name":"https://github.com/saleor/saleor/security/advisories/GHSA-ff69-fwjf-3c9w","tags":["x_refsource_CONFIRM","x_transferred"],"url":"https://github.com/saleor/saleor/security/advisories/GHSA-ff69-fwjf-3c9w"},{"name":"https://github.com/saleor/saleor/commit/36699c6f5c99590d24f46e3d5c5b1a3c2fd072e7","tags":["x_refsource_MISC","x_transferred"],"url":"https://github.com/saleor/saleor/commit/36699c6f5c99590d24f46e3d5c5b1a3c2fd072e7"}]}]}}