CVE-2026-39356 (GCVE-0-2026-39356)
Vulnerability from cvelistv5 – Published: 2026-04-07 19:58 – Updated: 2026-04-08 14:33
VLAI?
Title
SQL Injection via escapeName() in all Drizzle ORM SQL dialects
Summary
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.
Severity ?
7.5 (High)
CWE
- CWE-89 - Improper Neutralization of Special Elements used in an SQL Command ('SQL Injection')
Assigner
References
| URL | Tags | ||||
|---|---|---|---|---|---|
|
|||||
Impacted products
| Vendor | Product | Version | ||
|---|---|---|---|---|
| drizzle-team | drizzle-orm |
Affected:
< 0.45.2
Affected: >= 1.0.0-beta.2, < 1.0.0-beta.20 |
{
"containers": {
"adp": [
{
"metrics": [
{
"other": {
"content": {
"id": "CVE-2026-39356",
"options": [
{
"Exploitation": "none"
},
{
"Automatable": "yes"
},
{
"Technical Impact": "partial"
}
],
"role": "CISA Coordinator",
"timestamp": "2026-04-08T14:33:41.458749Z",
"version": "2.0.3"
},
"type": "ssvc"
}
}
],
"providerMetadata": {
"dateUpdated": "2026-04-08T14:33:54.466Z",
"orgId": "134c704f-9b21-4f2e-91b3-4a467353bcc0",
"shortName": "CISA-ADP"
},
"title": "CISA ADP Vulnrichment"
}
],
"cna": {
"affected": [
{
"product": "drizzle-orm",
"vendor": "drizzle-team",
"versions": [
{
"status": "affected",
"version": "\u003c 0.45.2"
},
{
"status": "affected",
"version": "\u003e= 1.0.0-beta.2, \u003c 1.0.0-beta.20"
}
]
}
],
"descriptions": [
{
"lang": "en",
"value": "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."
}
],
"metrics": [
{
"cvssV3_1": {
"attackComplexity": "LOW",
"attackVector": "NETWORK",
"availabilityImpact": "NONE",
"baseScore": 7.5,
"baseSeverity": "HIGH",
"confidentialityImpact": "HIGH",
"integrityImpact": "NONE",
"privilegesRequired": "NONE",
"scope": "UNCHANGED",
"userInteraction": "NONE",
"vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:N/A:N",
"version": "3.1"
}
}
],
"problemTypes": [
{
"descriptions": [
{
"cweId": "CWE-89",
"description": "CWE-89: Improper Neutralization of Special Elements used in an SQL Command (\u0027SQL Injection\u0027)",
"lang": "en",
"type": "CWE"
}
]
}
],
"providerMetadata": {
"dateUpdated": "2026-04-07T19:58:46.348Z",
"orgId": "a0819718-46f1-4df5-94e2-005712e83aaa",
"shortName": "GitHub_M"
},
"references": [
{
"name": "https://github.com/drizzle-team/drizzle-orm/security/advisories/GHSA-gpj5-g38j-94v9",
"tags": [
"x_refsource_CONFIRM"
],
"url": "https://github.com/drizzle-team/drizzle-orm/security/advisories/GHSA-gpj5-g38j-94v9"
}
],
"source": {
"advisory": "GHSA-gpj5-g38j-94v9",
"discovery": "UNKNOWN"
},
"title": "SQL Injection via escapeName() in all Drizzle ORM SQL dialects"
}
},
"cveMetadata": {
"assignerOrgId": "a0819718-46f1-4df5-94e2-005712e83aaa",
"assignerShortName": "GitHub_M",
"cveId": "CVE-2026-39356",
"datePublished": "2026-04-07T19:58:46.348Z",
"dateReserved": "2026-04-06T21:29:17.349Z",
"dateUpdated": "2026-04-08T14:33:54.466Z",
"state": "PUBLISHED"
},
"dataType": "CVE_RECORD",
"dataVersion": "5.2",
"vulnerability-lookup:meta": {
"epss": {
"cve": "CVE-2026-39356",
"date": "2026-05-04",
"epss": "0.00016",
"percentile": "0.03574"
},
"nvd": "{\"cve\":{\"id\":\"CVE-2026-39356\",\"sourceIdentifier\":\"security-advisories@github.com\",\"published\":\"2026-04-07T20:16:29.610\",\"lastModified\":\"2026-04-15T17:19:47.367\",\"vulnStatus\":\"Analyzed\",\"cveTags\":[],\"descriptions\":[{\"lang\":\"en\",\"value\":\"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.\"}],\"metrics\":{\"cvssMetricV31\":[{\"source\":\"security-advisories@github.com\",\"type\":\"Secondary\",\"cvssData\":{\"version\":\"3.1\",\"vectorString\":\"CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:N/A:N\",\"baseScore\":7.5,\"baseSeverity\":\"HIGH\",\"attackVector\":\"NETWORK\",\"attackComplexity\":\"LOW\",\"privilegesRequired\":\"NONE\",\"userInteraction\":\"NONE\",\"scope\":\"UNCHANGED\",\"confidentialityImpact\":\"HIGH\",\"integrityImpact\":\"NONE\",\"availabilityImpact\":\"NONE\"},\"exploitabilityScore\":3.9,\"impactScore\":3.6}]},\"weaknesses\":[{\"source\":\"security-advisories@github.com\",\"type\":\"Primary\",\"description\":[{\"lang\":\"en\",\"value\":\"CWE-89\"}]}],\"configurations\":[{\"nodes\":[{\"operator\":\"OR\",\"negate\":false,\"cpeMatch\":[{\"vulnerable\":true,\"criteria\":\"cpe:2.3:a:drizzle:drizzle:*:*:*:*:*:node.js:*:*\",\"versionEndExcluding\":\"0.45.2\",\"matchCriteriaId\":\"AC2CBAC7-A71B-431C-97E2-DDFCD8462EFF\"},{\"vulnerable\":true,\"criteria\":\"cpe:2.3:a:drizzle:drizzle:1.0.0:beta1:*:*:*:node.js:*:*\",\"matchCriteriaId\":\"60A3F747-3032-4D44-B1ED-155713253A2A\"},{\"vulnerable\":true,\"criteria\":\"cpe:2.3:a:drizzle:drizzle:1.0.0:beta11:*:*:*:node.js:*:*\",\"matchCriteriaId\":\"9996B93A-33E9-4B59-81FD-0237BA1640C5\"},{\"vulnerable\":true,\"criteria\":\"cpe:2.3:a:drizzle:drizzle:1.0.0:beta12:*:*:*:node.js:*:*\",\"matchCriteriaId\":\"9E745776-500B-4A8B-814A-2CC201D90B87\"},{\"vulnerable\":true,\"criteria\":\"cpe:2.3:a:drizzle:drizzle:1.0.0:beta13:*:*:*:node.js:*:*\",\"matchCriteriaId\":\"00F8DF93-174B-436A-AC04-A172D74166F1\"},{\"vulnerable\":true,\"criteria\":\"cpe:2.3:a:drizzle:drizzle:1.0.0:beta14:*:*:*:node.js:*:*\",\"matchCriteriaId\":\"31E46EFF-7701-4568-82EF-4C8F47F80A2C\"},{\"vulnerable\":true,\"criteria\":\"cpe:2.3:a:drizzle:drizzle:1.0.0:beta15:*:*:*:node.js:*:*\",\"matchCriteriaId\":\"B3255145-91F5-44D8-9E01-FE2B82C31361\"},{\"vulnerable\":true,\"criteria\":\"cpe:2.3:a:drizzle:drizzle:1.0.0:beta16:*:*:*:node.js:*:*\",\"matchCriteriaId\":\"0D9BA061-A130-4EF2-AE8D-8A7BB8F62DCF\"},{\"vulnerable\":true,\"criteria\":\"cpe:2.3:a:drizzle:drizzle:1.0.0:beta17:*:*:*:node.js:*:*\",\"matchCriteriaId\":\"72BA66E9-16BF-49CE-8311-02FD47A0D00C\"},{\"vulnerable\":true,\"criteria\":\"cpe:2.3:a:drizzle:drizzle:1.0.0:beta18:*:*:*:node.js:*:*\",\"matchCriteriaId\":\"B00B0A98-D5BE-40E4-BD71-E87414DFC428\"},{\"vulnerable\":true,\"criteria\":\"cpe:2.3:a:drizzle:drizzle:1.0.0:beta19:*:*:*:node.js:*:*\",\"matchCriteriaId\":\"874F5CFB-661B-4E23-BBFA-902842ADCAEC\"},{\"vulnerable\":true,\"criteria\":\"cpe:2.3:a:drizzle:drizzle:1.0.0:beta2:*:*:*:node.js:*:*\",\"matchCriteriaId\":\"B8932680-10AA-4DC4-89D9-B0F691591612\"},{\"vulnerable\":true,\"criteria\":\"cpe:2.3:a:drizzle:drizzle:1.0.0:beta3:*:*:*:node.js:*:*\",\"matchCriteriaId\":\"15C269C1-EDD4-4021-8356-0C8DACC21B5B\"},{\"vulnerable\":true,\"criteria\":\"cpe:2.3:a:drizzle:drizzle:1.0.0:beta4:*:*:*:node.js:*:*\",\"matchCriteriaId\":\"62138634-891B-41A8-8252-B0ED90D038DB\"},{\"vulnerable\":true,\"criteria\":\"cpe:2.3:a:drizzle:drizzle:1.0.0:beta5:*:*:*:node.js:*:*\",\"matchCriteriaId\":\"2A75B6D6-43B8-4A40-B710-F7A1796579CC\"},{\"vulnerable\":true,\"criteria\":\"cpe:2.3:a:drizzle:drizzle:1.0.0:beta6:*:*:*:node.js:*:*\",\"matchCriteriaId\":\"EF332766-43B3-4F35-A7E0-3EE1AAE303B6\"},{\"vulnerable\":true,\"criteria\":\"cpe:2.3:a:drizzle:drizzle:1.0.0:beta7:*:*:*:node.js:*:*\",\"matchCriteriaId\":\"CD68C495-63AE-45C0-A714-158FAFE4B4E1\"},{\"vulnerable\":true,\"criteria\":\"cpe:2.3:a:drizzle:drizzle:1.0.0:beta8:*:*:*:node.js:*:*\",\"matchCriteriaId\":\"EBA1CC9C-B1AA-4CF1-A9A5-7961F8624B50\"},{\"vulnerable\":true,\"criteria\":\"cpe:2.3:a:drizzle:drizzle:1.0.0:beta9:*:*:*:node.js:*:*\",\"matchCriteriaId\":\"67528631-A49B-40F7-8D1B-68F2BC208D2A\"}]}]}],\"references\":[{\"url\":\"https://github.com/drizzle-team/drizzle-orm/security/advisories/GHSA-gpj5-g38j-94v9\",\"source\":\"security-advisories@github.com\",\"tags\":[\"Vendor Advisory\"]}]}}",
"vulnrichment": {
"containers": "{\"adp\": [{\"title\": \"CISA ADP Vulnrichment\", \"metrics\": [{\"other\": {\"type\": \"ssvc\", \"content\": {\"id\": \"CVE-2026-39356\", \"role\": \"CISA Coordinator\", \"options\": [{\"Exploitation\": \"none\"}, {\"Automatable\": \"yes\"}, {\"Technical Impact\": \"partial\"}], \"version\": \"2.0.3\", \"timestamp\": \"2026-04-08T14:33:41.458749Z\"}}}], \"providerMetadata\": {\"orgId\": \"134c704f-9b21-4f2e-91b3-4a467353bcc0\", \"shortName\": \"CISA-ADP\", \"dateUpdated\": \"2026-04-08T14:33:47.867Z\"}}], \"cna\": {\"title\": \"SQL Injection via escapeName() in all Drizzle ORM SQL dialects\", \"source\": {\"advisory\": \"GHSA-gpj5-g38j-94v9\", \"discovery\": \"UNKNOWN\"}, \"metrics\": [{\"cvssV3_1\": {\"scope\": \"UNCHANGED\", \"version\": \"3.1\", \"baseScore\": 7.5, \"attackVector\": \"NETWORK\", \"baseSeverity\": \"HIGH\", \"vectorString\": \"CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:N/A:N\", \"integrityImpact\": \"NONE\", \"userInteraction\": \"NONE\", \"attackComplexity\": \"LOW\", \"availabilityImpact\": \"NONE\", \"privilegesRequired\": \"NONE\", \"confidentialityImpact\": \"HIGH\"}}], \"affected\": [{\"vendor\": \"drizzle-team\", \"product\": \"drizzle-orm\", \"versions\": [{\"status\": \"affected\", \"version\": \"\u003c 0.45.2\"}, {\"status\": \"affected\", \"version\": \"\u003e= 1.0.0-beta.2, \u003c 1.0.0-beta.20\"}]}], \"references\": [{\"url\": \"https://github.com/drizzle-team/drizzle-orm/security/advisories/GHSA-gpj5-g38j-94v9\", \"name\": \"https://github.com/drizzle-team/drizzle-orm/security/advisories/GHSA-gpj5-g38j-94v9\", \"tags\": [\"x_refsource_CONFIRM\"]}], \"descriptions\": [{\"lang\": \"en\", \"value\": \"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.\"}], \"problemTypes\": [{\"descriptions\": [{\"lang\": \"en\", \"type\": \"CWE\", \"cweId\": \"CWE-89\", \"description\": \"CWE-89: Improper Neutralization of Special Elements used in an SQL Command (\u0027SQL Injection\u0027)\"}]}], \"providerMetadata\": {\"orgId\": \"a0819718-46f1-4df5-94e2-005712e83aaa\", \"shortName\": \"GitHub_M\", \"dateUpdated\": \"2026-04-07T19:58:46.348Z\"}}}",
"cveMetadata": "{\"cveId\": \"CVE-2026-39356\", \"state\": \"PUBLISHED\", \"dateUpdated\": \"2026-04-08T14:33:54.466Z\", \"dateReserved\": \"2026-04-06T21:29:17.349Z\", \"assignerOrgId\": \"a0819718-46f1-4df5-94e2-005712e83aaa\", \"datePublished\": \"2026-04-07T19:58:46.348Z\", \"assignerShortName\": \"GitHub_M\"}",
"dataType": "CVE_RECORD",
"dataVersion": "5.2"
}
}
}
Loading…
Loading…
Experimental. This forecast is provided for visualization only and may change without notice. Do not use it for operational decisions.
Forecast uses a logistic model when the trend is rising, or an exponential decay model when the trend is falling. Fitted via linearized least squares.
Sightings
| Author | Source | Type | Date | Other |
|---|
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…
Loading…