CVE-2026-32763
HIGHSQL Injection via unsanitized JSON path keys when ignoring/silencing compilation errors or using `Kysely<any>`.
Title source: cnaDescription
Kysely is a type-safe TypeScript SQL query builder. Versions up to and including 0.28.11 has a SQL injection vulnerability in JSON path compilation for MySQL and SQLite dialects. The `visitJSONPathLeg()` function appends user-controlled values from `.key()` and `.at()` directly into single-quoted JSON path string literals (`'$.key'`) without escaping single quotes. An attacker can break out of the JSON path string context and inject arbitrary SQL. This is inconsistent with `sanitizeIdentifier()`, which properly doubles delimiter characters for identifiers — both are non-parameterizable SQL constructs requiring manual escaping, but only identifiers are protected. Version 0.28.12 fixes the issue.
References (3)
Core 3
Core References
X_Refsource_Confirm x_refsource_confirm
https://github.com/kysely-org/kysely/security/advisories/GHSA-wmrf-hv6w-mr66
X_Refsource_Misc x_refsource_misc
https://github.com/kysely-org/kysely/commit/0a602bff2f442f6c26d5e047ca8f8715179f6d24
X_Refsource_Misc x_refsource_misc
https://github.com/kysely-org/kysely/releases/tag/v0.28.12
Scores
CVSS v3
8.2
EPSS
0.0042
EPSS Percentile
33.3%
Attack Vector
NETWORK
CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:L/A:N
CISA SSVC
Vulnrichment
Exploitation
poc
Automatable
yes
Technical Impact
partial
Details
CWE
CWE-89
Status
published
Products (3)
kysely/kysely
0.26.0 - 0.28.12
kysely-org/kysely
>= 0.26.0, < 0.28.12
npm/kysely
0.26.0 - 0.28.12npm
Published
Mar 20, 2026
Tracked Since
Mar 20, 2026