CVE-2026-42353 is a high-severity path traversal vulnerability in i18next-http-middleware (npm), affecting versions < 3.9.3. It is fixed in 3.9.3.
Summary Versions of i18next-http-middleware prior to 3.9.3 pass the user-controlled lng and ns values from getResourcesHandler directly into i18next.services.backendConnector.load(languages, namespaces, …) without any sanitisation. Depending on which backend is configured, the unvalidated path segments enable one of two attacks: Filesystem path traversal when the middleware is paired with i18next-fs-backend (or any backend that interpolates lng / ns into a filesystem path). Server-Side Request Forgery (SSRF) when the middleware is paired with i18next-http-backend (or any backend that interpolates into an HTTP URL). Example request: with i18next-fs-backend reads the attacker-chosen file from disk; with i18next-http-backend reshapes the outgoing URL to target an internal service. Impact Arbitrary file read via fs-style backends, any file the Node process can read becomes reachable (source, configuration, .ssh keys, .env, Docker secrets, etc.). SSRF via http-style backends, requests to internal IPs / hostnames not normally reachable from the internet; combined with cloud metadata endpoints this can escalate to credential theft. Unbounded growth of i18next.options.ns, a now-incidental amplification: the pre-patch getResourcesHandler pushed every unique ns value into the shared i18next.options.ns singleton array without validation or bounds, enabling memory exhaustion from repeated unique payloads. The severity is bounded by the backend in place, but the middleware itself exposed the unsanitised path; this is the "weakest link" layer. Affected versions < 3.9.3. Patch Fixed in 3.9.3. The patch introduces utils.isSafeIdentifier and applies it in getResourcesHandler before lng and ns reach the backend connector: isSafeIdentifier uses a denylist approach, it still accepts any legitimate i18next language-code shape (i18next FAQ), rejecting: .. sequences (relative path traversal) path separators (/, \) control characters (C0/C1) prototype keys (proto / constructor / prototype) empty strings and values longer than 128 characters Unsafe values are dropped; only safe values reach the backend. The fix is a defence-in-depth layer on top of any sanitisation the backend itself may apply. Workarounds No workaround short of upgrading. Front-proxying the middleware with a WAF rule that rejects requests containing .., /, \, or URL-structure characters in lng / ns is a partial mitigation. Upgrading the configured backend (i18next-fs-backend ≥ 2.6.4, i18next-http-backend ≥ 3.0.5) also closes the same attack at the next layer. Related advisories fixed in the same release GHSA-5fgg-jcpf-8jjw, prototype pollution via setPath and missingKeyHandler. Independently fixable, filed separately per CNA rules. GHSA-c3h8-g69v-pjrg, HTTP response splitting + XSS-filter bypass (CVE-2026-41683). Credits Discovered via an internal security audit of the i18next ecosystem. Resources CWE-22: Path Traversal CWE-918: Server-Side Request Forgery (SSRF) (specific sub-case when paired with an HTTP backend) i18next FAQ: language code formatting
Input manipulates file paths to reach files outside the intended directory, such as configuration or credential files. Typical impact: unauthorized file read or write outside the intended directory.
CVE-2026-42353 has a CVSS score of 8.2 (High). The vector is network-reachable, no privileges required, and no user interaction. A CVSS score reflects the worst-case severity of the vulnerability, not your specific exposure. Whether this affects your application depends on whether the vulnerable code is present and reachable in your environment.
A fixed version is available (3.9.3). Upgrading removes the vulnerable code path.
npm
i18next-http-middleware (< 3.9.3)i18next-http-middleware → 3.9.3 (npm)Severity tells you how bad this could be in the worst case. It does not tell you whether you are exposed. Exploitability and impact are functions of runtime truth: whether the vulnerable code is present, reachable, and actually executes in your application. A vulnerable package can sit in your dependency tree and never run.
Kodem, an Intelligent Application Security platform, uses runtime intelligence to reveal which vulnerabilities actually execute in production, so teams prioritize the ones that genuinely matter instead of chasing every advisory.
Kodem's runtime-powered SCA identifies whether CVE-2026-42353 is reachable in your applications. Explore open-source security for your team.
See if CVE-2026-42353 is reachable in your applications. Get a demo
Already deployed Kodem? See CVE-2026-42353 in your environment →Upgrade i18next-http-middleware to 3.9.3 or later to resolve this vulnerability.
Kodem Kai can prioritize this vulnerability in your dependency tree and generate a fix recommendation.
CVE-2026-42353 is a high-severity path traversal vulnerability in i18next-http-middleware (npm), affecting versions < 3.9.3. It is fixed in 3.9.3. Input manipulates file paths to reach files outside the intended directory, such as configuration or credential files.
CVE-2026-42353 has a CVSS score of 8.2 (High). This score reflects the worst-case severity of the vulnerability, not your specific exposure. Whether it represents real risk in your environment depends on whether the vulnerable code is present and reachable.
i18next-http-middleware (npm) versions < 3.9.3 is affected.
Yes. CVE-2026-42353 is fixed in 3.9.3. Upgrade to this version or later.
Whether CVE-2026-42353 is exploitable in your environment depends on whether the vulnerable code is present and reachable. A CVSS score is a worst-case rating; it does not account for your specific deployment, configuration, or usage patterns. Kodem, an Intelligent Application Security platform, uses runtime intelligence to show which vulnerabilities actually execute in production, so you can focus on the ones that represent real risk. Get a demo
Exploitability and impact are not fixed properties of a CVE. They depend on runtime truth: whether the vulnerable code is present, reachable, and actually executes in your application. A high CVSS score on a dependency that never runs is not the same as real risk. Kodem, an Intelligent Application Security platform, uses runtime intelligence to reveal which vulnerabilities actually execute in production, so teams prioritize the ones that genuinely matter.
Upgrade i18next-http-middleware to 3.9.3 or later.