{"api_version":"1","generated_at":"2026-04-15T21:29:28+00:00","cve":"CVE-2026-39356","urls":{"html":"https://cve.report/CVE-2026-39356","api":"https://cve.report/api/cve/CVE-2026-39356.json","docs":"https://cve.report/api","cve_org":"https://www.cve.org/CVERecord?id=CVE-2026-39356","nvd":"https://nvd.nist.gov/vuln/detail/CVE-2026-39356"},"summary":{"title":"SQL Injection via escapeName() in all Drizzle ORM SQL dialects","description":"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.","state":"PUBLISHED","assigner":"GitHub_M","published_at":"2026-04-07 20:16:29","updated_at":"2026-04-15 17:19:47"},"problem_types":["CWE-89","CWE-89 CWE-89: Improper Neutralization of Special Elements used in an SQL Command ('SQL Injection')"],"metrics":[{"version":"3.1","source":"security-advisories@github.com","type":"Secondary","score":"7.5","severity":"HIGH","vector":"CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:N/A:N","data":{"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"}},{"version":"3.1","source":"CNA","type":"DECLARED","score":"7.5","severity":"HIGH","vector":"CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:N/A:N","data":{"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"}}],"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","refsource":"security-advisories@github.com","tags":["Vendor Advisory"],"title":"","mime":"","httpstatus":"","archivestatus":"0"},{"url":"https://www.cve.org/CVERecord?id=CVE-2026-39356","name":"CVE Program record","refsource":"CVE.ORG","tags":["canonical"]},{"url":"https://nvd.nist.gov/vuln/detail/CVE-2026-39356","name":"NVD vulnerability detail","refsource":"NVD","tags":["canonical","analysis"]}],"affected":[{"source":"CNA","vendor":"drizzle-team","product":"drizzle-orm","version":"affected < 0.45.2","platforms":[]},{"source":"CNA","vendor":"drizzle-team","product":"drizzle-orm","version":"affected >= 1.0.0-beta.2, < 1.0.0-beta.20","platforms":[]}],"timeline":[],"solutions":[],"workarounds":[],"exploits":[],"credits":[],"nvd_cpes":[{"cve_year":"2026","cve_id":"39356","vulnerable":"1","versionEndIncluding":"","cpe1":"cpe","cpe2":"2.3","cpe3":"a","cpe4":"drizzle","cpe5":"drizzle","cpe6":"*","cpe7":"*","cpe8":"*","cpe9":"*","cpe10":"*","cpe11":"node.js","cpe12":"*","cpe13":"*"},{"cve_year":"2026","cve_id":"39356","vulnerable":"1","versionEndIncluding":"","cpe1":"cpe","cpe2":"2.3","cpe3":"a","cpe4":"drizzle","cpe5":"drizzle","cpe6":"1.0.0","cpe7":"beta1","cpe8":"*","cpe9":"*","cpe10":"*","cpe11":"node.js","cpe12":"*","cpe13":"*"},{"cve_year":"2026","cve_id":"39356","vulnerable":"1","versionEndIncluding":"","cpe1":"cpe","cpe2":"2.3","cpe3":"a","cpe4":"drizzle","cpe5":"drizzle","cpe6":"1.0.0","cpe7":"beta11","cpe8":"*","cpe9":"*","cpe10":"*","cpe11":"node.js","cpe12":"*","cpe13":"*"},{"cve_year":"2026","cve_id":"39356","vulnerable":"1","versionEndIncluding":"","cpe1":"cpe","cpe2":"2.3","cpe3":"a","cpe4":"drizzle","cpe5":"drizzle","cpe6":"1.0.0","cpe7":"beta12","cpe8":"*","cpe9":"*","cpe10":"*","cpe11":"node.js","cpe12":"*","cpe13":"*"},{"cve_year":"2026","cve_id":"39356","vulnerable":"1","versionEndIncluding":"","cpe1":"cpe","cpe2":"2.3","cpe3":"a","cpe4":"drizzle","cpe5":"drizzle","cpe6":"1.0.0","cpe7":"beta13","cpe8":"*","cpe9":"*","cpe10":"*","cpe11":"node.js","cpe12":"*","cpe13":"*"},{"cve_year":"2026","cve_id":"39356","vulnerable":"1","versionEndIncluding":"","cpe1":"cpe","cpe2":"2.3","cpe3":"a","cpe4":"drizzle","cpe5":"drizzle","cpe6":"1.0.0","cpe7":"beta14","cpe8":"*","cpe9":"*","cpe10":"*","cpe11":"node.js","cpe12":"*","cpe13":"*"},{"cve_year":"2026","cve_id":"39356","vulnerable":"1","versionEndIncluding":"","cpe1":"cpe","cpe2":"2.3","cpe3":"a","cpe4":"drizzle","cpe5":"drizzle","cpe6":"1.0.0","cpe7":"beta15","cpe8":"*","cpe9":"*","cpe10":"*","cpe11":"node.js","cpe12":"*","cpe13":"*"},{"cve_year":"2026","cve_id":"39356","vulnerable":"1","versionEndIncluding":"","cpe1":"cpe","cpe2":"2.3","cpe3":"a","cpe4":"drizzle","cpe5":"drizzle","cpe6":"1.0.0","cpe7":"beta16","cpe8":"*","cpe9":"*","cpe10":"*","cpe11":"node.js","cpe12":"*","cpe13":"*"},{"cve_year":"2026","cve_id":"39356","vulnerable":"1","versionEndIncluding":"","cpe1":"cpe","cpe2":"2.3","cpe3":"a","cpe4":"drizzle","cpe5":"drizzle","cpe6":"1.0.0","cpe7":"beta17","cpe8":"*","cpe9":"*","cpe10":"*","cpe11":"node.js","cpe12":"*","cpe13":"*"},{"cve_year":"2026","cve_id":"39356","vulnerable":"1","versionEndIncluding":"","cpe1":"cpe","cpe2":"2.3","cpe3":"a","cpe4":"drizzle","cpe5":"drizzle","cpe6":"1.0.0","cpe7":"beta18","cpe8":"*","cpe9":"*","cpe10":"*","cpe11":"node.js","cpe12":"*","cpe13":"*"},{"cve_year":"2026","cve_id":"39356","vulnerable":"1","versionEndIncluding":"","cpe1":"cpe","cpe2":"2.3","cpe3":"a","cpe4":"drizzle","cpe5":"drizzle","cpe6":"1.0.0","cpe7":"beta19","cpe8":"*","cpe9":"*","cpe10":"*","cpe11":"node.js","cpe12":"*","cpe13":"*"},{"cve_year":"2026","cve_id":"39356","vulnerable":"1","versionEndIncluding":"","cpe1":"cpe","cpe2":"2.3","cpe3":"a","cpe4":"drizzle","cpe5":"drizzle","cpe6":"1.0.0","cpe7":"beta2","cpe8":"*","cpe9":"*","cpe10":"*","cpe11":"node.js","cpe12":"*","cpe13":"*"},{"cve_year":"2026","cve_id":"39356","vulnerable":"1","versionEndIncluding":"","cpe1":"cpe","cpe2":"2.3","cpe3":"a","cpe4":"drizzle","cpe5":"drizzle","cpe6":"1.0.0","cpe7":"beta3","cpe8":"*","cpe9":"*","cpe10":"*","cpe11":"node.js","cpe12":"*","cpe13":"*"},{"cve_year":"2026","cve_id":"39356","vulnerable":"1","versionEndIncluding":"","cpe1":"cpe","cpe2":"2.3","cpe3":"a","cpe4":"drizzle","cpe5":"drizzle","cpe6":"1.0.0","cpe7":"beta4","cpe8":"*","cpe9":"*","cpe10":"*","cpe11":"node.js","cpe12":"*","cpe13":"*"},{"cve_year":"2026","cve_id":"39356","vulnerable":"1","versionEndIncluding":"","cpe1":"cpe","cpe2":"2.3","cpe3":"a","cpe4":"drizzle","cpe5":"drizzle","cpe6":"1.0.0","cpe7":"beta5","cpe8":"*","cpe9":"*","cpe10":"*","cpe11":"node.js","cpe12":"*","cpe13":"*"},{"cve_year":"2026","cve_id":"39356","vulnerable":"1","versionEndIncluding":"","cpe1":"cpe","cpe2":"2.3","cpe3":"a","cpe4":"drizzle","cpe5":"drizzle","cpe6":"1.0.0","cpe7":"beta6","cpe8":"*","cpe9":"*","cpe10":"*","cpe11":"node.js","cpe12":"*","cpe13":"*"},{"cve_year":"2026","cve_id":"39356","vulnerable":"1","versionEndIncluding":"","cpe1":"cpe","cpe2":"2.3","cpe3":"a","cpe4":"drizzle","cpe5":"drizzle","cpe6":"1.0.0","cpe7":"beta7","cpe8":"*","cpe9":"*","cpe10":"*","cpe11":"node.js","cpe12":"*","cpe13":"*"},{"cve_year":"2026","cve_id":"39356","vulnerable":"1","versionEndIncluding":"","cpe1":"cpe","cpe2":"2.3","cpe3":"a","cpe4":"drizzle","cpe5":"drizzle","cpe6":"1.0.0","cpe7":"beta8","cpe8":"*","cpe9":"*","cpe10":"*","cpe11":"node.js","cpe12":"*","cpe13":"*"},{"cve_year":"2026","cve_id":"39356","vulnerable":"1","versionEndIncluding":"","cpe1":"cpe","cpe2":"2.3","cpe3":"a","cpe4":"drizzle","cpe5":"drizzle","cpe6":"1.0.0","cpe7":"beta9","cpe8":"*","cpe9":"*","cpe10":"*","cpe11":"node.js","cpe12":"*","cpe13":"*"}],"vendor_comments":[],"enrichments":{"kev":null,"epss":{"cve_year":"2026","cve_id":"39356","cve":"CVE-2026-39356","epss":"0.000430000","percentile":"0.130210000","score_date":"2026-04-13","updated_at":"2026-04-14 00:12:05"},"legacy_qids":[]},"source_records":{"cve_program":{"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":"< 0.45.2"},{"status":"affected","version":">= 1.0.0-beta.2, < 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 ('SQL Injection')","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"},"nvd":{"publishedDate":"2026-04-07 20:16:29","lastModifiedDate":"2026-04-15 17:19:47","problem_types":["CWE-89","CWE-89 CWE-89: Improper Neutralization of Special Elements used in an SQL Command ('SQL Injection')"],"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}]},"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"}]}]}]},"legacy_mitre":{"record":{"CveYear":"2026","CveId":"39356","Ordinal":"1","Title":"SQL Injection via escapeName() in all Drizzle ORM SQL dialects","CVE":"CVE-2026-39356","Year":"2026"},"notes":[{"CveYear":"2026","CveId":"39356","Ordinal":"1","NoteData":"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.","Type":"Description","Title":"SQL Injection via escapeName() in all Drizzle ORM SQL dialects"}]}}}