GHSA-gpj5-g38j-94v9 · Severity: high · Ecosystem: npm — Drizzle ORM has SQL injection via improperly escaped SQL identifiers
Drizzle is a modern TypeScript ORM. Prior to 0.45.2 and 1.0.0-beta.20, Drizzle ORM improperly escaped quoted SQL identifiers in its dialect-specific escapeName() implementations. In affected versions, embedded identifier delimiters were not escaped before the identifier was wrapped in quotes or backticks. As a result, applications that pass attacker-controlled input to APIs that construct SQL identifiers or aliases, such as sql.identifier(), .as(), may allow an attacker to terminate the quoted identifier and inject SQL. This vulnerability is fixed in 0.45.2 and 1.0.0-beta.20.
Conclusion & alert: CVE-2026-39356 is rated Low Risk (33.3/100): CVSS High severity, with low exploitation likelihood (EPSS 0.03%). Mandatory action: Monitor for updates and reassess as exploit intelligence or EPSS changes.
Risk is dynamic; we continuously reassess and refresh what is shown on this page as upstream context changes.
EPSS lead: Daily EPSS estimates relative likelihood of exploitation; percentile ranks this CVE among scored vulnerabilities (higher = more severe relative rank).
| # | Date | Old EPSS score | New EPSS score | Delta (New - Old) |
|---|---|---|---|---|
| 1 | 2026-04-08 | — | 0.03% | — |
Full EPSS history (1 record total)
CVSS metrics for this CVE.
| Base score | Version | Severity | Vector | Exploitability | Impact | Score source |
|---|---|---|---|---|---|---|
| 7.5 | 3.1 | HIGH |
|
3.9 | 3.6 | [email protected] |
GHSA-gpj5-g38j-94v9 · Severity: high · Ecosystem: npm — Drizzle ORM has SQL injection via improperly escaped SQL identifiers
| Vendor | Product | Version | Raw CPE |
|---|---|---|---|
| drizzle | drizzle | < 0.45.2 | cpe:2.3:a:drizzle:drizzle:*:*:*:*:*:node.js:*:* |
| drizzle | drizzle | 1.0.0 | cpe:2.3:a:drizzle:drizzle:1.0.0:beta1:*:*:*:node.js:*:* |
| drizzle | drizzle | 1.0.0 | cpe:2.3:a:drizzle:drizzle:1.0.0:beta11:*:*:*:node.js:*:* |
| drizzle | drizzle | 1.0.0 | cpe:2.3:a:drizzle:drizzle:1.0.0:beta12:*:*:*:node.js:*:* |
| drizzle | drizzle | 1.0.0 | cpe:2.3:a:drizzle:drizzle:1.0.0:beta13:*:*:*:node.js:*:* |
| drizzle | drizzle | 1.0.0 | cpe:2.3:a:drizzle:drizzle:1.0.0:beta14:*:*:*:node.js:*:* |
| drizzle | drizzle | 1.0.0 | cpe:2.3:a:drizzle:drizzle:1.0.0:beta15:*:*:*:node.js:*:* |
| drizzle | drizzle | 1.0.0 | cpe:2.3:a:drizzle:drizzle:1.0.0:beta16:*:*:*:node.js:*:* |
| drizzle | drizzle | 1.0.0 | cpe:2.3:a:drizzle:drizzle:1.0.0:beta17:*:*:*:node.js:*:* |
| drizzle | drizzle | 1.0.0 | cpe:2.3:a:drizzle:drizzle:1.0.0:beta18:*:*:*:node.js:*:* |
| drizzle | drizzle | 1.0.0 | cpe:2.3:a:drizzle:drizzle:1.0.0:beta19:*:*:*:node.js:*:* |
| drizzle | drizzle | 1.0.0 | cpe:2.3:a:drizzle:drizzle:1.0.0:beta2:*:*:*:node.js:*:* |
| drizzle | drizzle | 1.0.0 | cpe:2.3:a:drizzle:drizzle:1.0.0:beta3:*:*:*:node.js:*:* |
| drizzle | drizzle | 1.0.0 | cpe:2.3:a:drizzle:drizzle:1.0.0:beta4:*:*:*:node.js:*:* |
| drizzle | drizzle | 1.0.0 | cpe:2.3:a:drizzle:drizzle:1.0.0:beta5:*:*:*:node.js:*:* |
| drizzle | drizzle | 1.0.0 | cpe:2.3:a:drizzle:drizzle:1.0.0:beta6:*:*:*:node.js:*:* |
| drizzle | drizzle | 1.0.0 | cpe:2.3:a:drizzle:drizzle:1.0.0:beta7:*:*:*:node.js:*:* |
| drizzle | drizzle | 1.0.0 | cpe:2.3:a:drizzle:drizzle:1.0.0:beta8:*:*:*:node.js:*:* |
| drizzle | drizzle | 1.0.0 | cpe:2.3:a:drizzle:drizzle:1.0.0:beta9:*:*:*:node.js:*:* |
| URL | Tags |
|---|---|
| https://github.com/drizzle-team/drizzle-orm/security/advisories/GHSA-gpj5-g38j-94v9 | Vendor Advisory |