FKIE_CVE-2025-61686

Vulnerability from fkie_nvd - Published: 2026-01-10 03:15 - Updated: 2026-02-04 14:52
Severity ?
Summary
React Router is a router for React. In @react-router/node versions 7.0.0 through 7.9.3, @remix-run/deno prior to version 2.17.2, and @remix-run/node prior to version 2.17.2, if createFileSessionStorage() is being used from @react-router/node (or @remix-run/node/@remix-run/deno in Remix v2) with an unsigned cookie, it is possible for an attacker to cause the session to try to read/write from a location outside the specified session file directory. The success of the attack would depend on the permissions of the web server process to access those files. Read files cannot be returned directly to the attacker. Session file reads would only succeed if the file matched the expected session file format. If the file matched the session file format, the data would be populated into the server side session but not directly returned to the attacker unless the application logic returned specific session information. This issue has been patched in @react-router/node version 7.9.4, @remix-run/deno version 2.17.2, and @remix-run/node version 2.17.2.
Impacted products

{
  "configurations": [
    {
      "nodes": [
        {
          "cpeMatch": [
            {
              "criteria": "cpe:2.3:a:shopify:react-router\\/node:*:*:*:*:*:node.js:*:*",
              "matchCriteriaId": "1E0C856C-476D-482F-8047-7F4D5F0B4204",
              "versionEndExcluding": "7.9.4",
              "versionStartIncluding": "7.0.0",
              "vulnerable": true
            },
            {
              "criteria": "cpe:2.3:a:shopify:remix-run\\/deno:*:*:*:*:*:node.js:*:*",
              "matchCriteriaId": "B47283CD-6965-448D-98CA-2A1BEED89A74",
              "versionEndExcluding": "2.17.2",
              "vulnerable": true
            },
            {
              "criteria": "cpe:2.3:a:shopify:remix-run\\/node:*:*:*:*:*:node.js:*:*",
              "matchCriteriaId": "C506FB64-B70B-40CF-8A14-C7BA394D1814",
              "versionEndExcluding": "2.17.2",
              "vulnerable": true
            }
          ],
          "negate": false,
          "operator": "OR"
        }
      ]
    }
  ],
  "cveTags": [],
  "descriptions": [
    {
      "lang": "en",
      "value": "React Router is a router for React. In @react-router/node versions 7.0.0 through 7.9.3, @remix-run/deno prior to version 2.17.2, and @remix-run/node prior to version 2.17.2, if createFileSessionStorage() is being used from @react-router/node (or @remix-run/node/@remix-run/deno in Remix v2) with an unsigned cookie, it is possible for an attacker to cause the session to try to read/write from a location outside the specified session file directory. The success of the attack would depend on the permissions of the web server process to access those files. Read files cannot be returned directly to the attacker. Session file reads would only succeed if the file matched the expected session file format. If the file matched the session file format, the data would be populated into the server side session but not directly returned to the attacker unless the application logic returned specific session information. This issue has been patched in @react-router/node version 7.9.4, @remix-run/deno version 2.17.2, and @remix-run/node version 2.17.2."
    },
    {
      "lang": "es",
      "value": "React Router es un router para React. En las versiones de @react-router/node 7.0.0 a 7.9.3, @remix-run/deno anteriores a la versi\u00f3n 2.17.2, y @remix-run/node anteriores a la versi\u00f3n 2.17.2, si se utiliza createFileSessionStorage() de @react-router/node (o @remix-run/node/@remix-run/deno en Remix v2) con una cookie sin firmar, es posible que un atacante haga que la sesi\u00f3n intente leer/escribir desde una ubicaci\u00f3n fuera del directorio de archivos de sesi\u00f3n especificado. El \u00e9xito del ataque depender\u00eda de los permisos del proceso del servidor web para acceder a esos archivos. Los archivos le\u00eddos no pueden ser devueltos directamente al atacante. Las lecturas de archivos de sesi\u00f3n solo tendr\u00edan \u00e9xito si el archivo coincidiera con el formato de archivo de sesi\u00f3n esperado. Si el archivo coincidiera con el formato de archivo de sesi\u00f3n, los datos se poblar\u00edan en la sesi\u00f3n del lado del servidor pero no se devolver\u00edan directamente al atacante a menos que la l\u00f3gica de la aplicaci\u00f3n devolviera informaci\u00f3n espec\u00edfica de la sesi\u00f3n. Este problema ha sido parcheado en la versi\u00f3n 7.9.4 de @react-router/node, la versi\u00f3n 2.17.2 de @remix-run/deno y la versi\u00f3n 2.17.2 de @remix-run/node."
    }
  ],
  "id": "CVE-2025-61686",
  "lastModified": "2026-02-04T14:52:53.283",
  "metrics": {
    "cvssMetricV31": [
      {
        "cvssData": {
          "attackComplexity": "LOW",
          "attackVector": "NETWORK",
          "availabilityImpact": "HIGH",
          "baseScore": 9.1,
          "baseSeverity": "CRITICAL",
          "confidentialityImpact": "NONE",
          "integrityImpact": "HIGH",
          "privilegesRequired": "NONE",
          "scope": "UNCHANGED",
          "userInteraction": "NONE",
          "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:H/A:H",
          "version": "3.1"
        },
        "exploitabilityScore": 3.9,
        "impactScore": 5.2,
        "source": "security-advisories@github.com",
        "type": "Secondary"
      }
    ]
  },
  "published": "2026-01-10T03:15:48.283",
  "references": [
    {
      "source": "security-advisories@github.com",
      "tags": [
        "Third Party Advisory"
      ],
      "url": "https://github.com/remix-run/react-router/security/advisories/GHSA-9583-h5hc-x8cw"
    }
  ],
  "sourceIdentifier": "security-advisories@github.com",
  "vulnStatus": "Analyzed",
  "weaknesses": [
    {
      "description": [
        {
          "lang": "en",
          "value": "CWE-22"
        }
      ],
      "source": "security-advisories@github.com",
      "type": "Primary"
    }
  ]
}


Log in or create an account to share your comment.




Tags
Taxonomy of the tags.


Loading…

Loading…

Loading…

Sightings

Author Source Type Date

Nomenclature

  • Seen: The vulnerability was mentioned, discussed, or observed by the user.
  • Confirmed: The vulnerability has been validated from an analyst's perspective.
  • Published Proof of Concept: A public proof of concept is available for this vulnerability.
  • Exploited: The vulnerability was observed as exploited by the user who reported the sighting.
  • Patched: The vulnerability was observed as successfully patched by the user who reported the sighting.
  • Not exploited: The vulnerability was not observed as exploited by the user who reported the sighting.
  • Not confirmed: The user expressed doubt about the validity of the vulnerability.
  • Not patched: The vulnerability was not observed as successfully patched by the user who reported the sighting.


Loading…

Detection rules are retrieved from Rulezet.

Loading…

Loading…