CVE-2024-31205
08.04.2024, 15:15
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`.
| Vendor | Product | Version |
|---|---|---|
| saleor | saleor | 3.10.0 ≤ 𝑥 < 3.14.64 |
| saleor | saleor | 3.15.0 ≤ 𝑥 < 3.15.39 |
| saleor | saleor | 3.16.0 ≤ 𝑥 < 3.16.39 |
| saleor | saleor | 3.17.0 ≤ 𝑥 < 3.17.35 |
| saleor | saleor | 3.18.0 ≤ 𝑥 < 3.18.31 |
| saleor | saleor | 3.19.0 ≤ 𝑥 < 3.19.19 |
𝑥
= Vulnerable software versions
Common Weakness Enumeration
References