{"api_version":"1","generated_at":"2026-06-05T17:40:43+00:00","cve":"CVE-2026-10879","urls":{"html":"https://cve.report/CVE-2026-10879","api":"https://cve.report/api/cve/CVE-2026-10879.json","docs":"https://cve.report/api","cve_org":"https://www.cve.org/CVERecord?id=CVE-2026-10879","nvd":"https://nvd.nist.gov/vuln/detail/CVE-2026-10879"},"summary":{"title":"DBI versions before 1.648 for Perl have a heap overflow when preparsing SQL statements with more than 9 binders","description":"DBI versions before 1.648 for Perl have a heap overflow when preparsing SQL statements with more than 9 binders.\n\nThe preparse method expands SQL placeholder characters to numbered binders of the form :pN, but only allocates three characters per binder in the buffer.  Placeholders 10-99 require four characters, 100-999 require five characters, et cetera.","state":"PUBLISHED","assigner":"CPANSec","published_at":"2026-06-05 15:16:46","updated_at":"2026-06-05 15:56:37"},"problem_types":["CWE-787","CWE-787 CWE-787 (Out-of-bounds Write)"],"metrics":[],"references":[{"url":"https://metacpan.org/release/HMBRAND/DBI-1.648/changes","name":"https://metacpan.org/release/HMBRAND/DBI-1.648/changes","refsource":"9b29abf9-4ab0-4765-b253-1875cd9b441e","tags":[],"title":"","mime":"","httpstatus":"","archivestatus":"0"},{"url":"https://github.com/perl5-dbi/dbi/commit/af79036c07aa9a457971c0f4136e37c85dc20978.patch","name":"https://github.com/perl5-dbi/dbi/commit/af79036c07aa9a457971c0f4136e37c85dc20978.patch","refsource":"9b29abf9-4ab0-4765-b253-1875cd9b441e","tags":[],"title":"","mime":"","httpstatus":"","archivestatus":"0"},{"url":"https://www.cve.org/CVERecord?id=CVE-2026-10879","name":"CVE Program record","refsource":"CVE.ORG","tags":["canonical"]},{"url":"https://nvd.nist.gov/vuln/detail/CVE-2026-10879","name":"NVD vulnerability detail","refsource":"NVD","tags":["canonical","analysis"]}],"affected":[{"source":"CNA","vendor":"HMBRAND","product":"DBI","version":"affected 1.648 custom","platforms":[]}],"timeline":[{"source":"CNA","time":"2026-04-25T00:00:00.000Z","lang":"en","value":"Issue reported to CPANSec."},{"source":"CNA","time":"2026-05-28T00:00:00.000Z","lang":"en","value":"Commit fixed the issue in DBI."},{"source":"CNA","time":"2026-06-04T00:00:00.000Z","lang":"en","value":"DBI 1.648 released."}],"solutions":[{"source":"CNA","title":"","value":"Upgrade to DBI 1.648 or later.","time":"","lang":"en"}],"workarounds":[],"exploits":[],"credits":[],"nvd_cpes":[],"vendor_comments":[],"enrichments":{"kev":null,"epss":null,"legacy_qids":[]},"source_records":{"cve_program":{"containers":{"cna":{"affected":[{"collectionURL":"https://cpan.org/modules","defaultStatus":"unaffected","packageName":"DBI","product":"DBI","programFiles":["DBI.xs"],"repo":"https://github.com/perl5-dbi/dbi","vendor":"HMBRAND","versions":[{"lessThan":"1.648","status":"affected","version":"0","versionType":"custom"}]}],"descriptions":[{"lang":"en","value":"DBI versions before 1.648 for Perl have a heap overflow when preparsing SQL statements with more than 9 binders.\n\nThe preparse method expands SQL placeholder characters to numbered binders of the form :pN, but only allocates three characters per binder in the buffer.  Placeholders 10-99 require four characters, 100-999 require five characters, et cetera."}],"problemTypes":[{"descriptions":[{"cweId":"CWE-787","description":"CWE-787 (Out-of-bounds Write)","lang":"en","type":"CWE"}]}],"providerMetadata":{"dateUpdated":"2026-06-05T14:30:58.497Z","orgId":"9b29abf9-4ab0-4765-b253-1875cd9b441e","shortName":"CPANSec"},"references":[{"tags":["release-notes"],"url":"https://metacpan.org/release/HMBRAND/DBI-1.648/changes"},{"tags":["patch"],"url":"https://github.com/perl5-dbi/dbi/commit/af79036c07aa9a457971c0f4136e37c85dc20978.patch"}],"solutions":[{"lang":"en","value":"Upgrade to DBI 1.648 or later."}],"source":{"discovery":"UNKNOWN"},"timeline":[{"lang":"en","time":"2026-04-25T00:00:00.000Z","value":"Issue reported to CPANSec."},{"lang":"en","time":"2026-05-28T00:00:00.000Z","value":"Commit fixed the issue in DBI."},{"lang":"en","time":"2026-06-04T00:00:00.000Z","value":"DBI 1.648 released."}],"title":"DBI versions before 1.648 for Perl have a heap overflow when preparsing SQL statements with more than 9 binders","x_generator":{"engine":"cpansec-cna-tool 0.1"}}},"cveMetadata":{"assignerOrgId":"9b29abf9-4ab0-4765-b253-1875cd9b441e","assignerShortName":"CPANSec","cveId":"CVE-2026-10879","datePublished":"2026-06-05T14:30:58.497Z","dateReserved":"2026-06-04T16:34:48.978Z","dateUpdated":"2026-06-05T14:30:58.497Z","state":"PUBLISHED"},"dataType":"CVE_RECORD","dataVersion":"5.2"},"nvd":{"publishedDate":"2026-06-05 15:16:46","lastModifiedDate":"2026-06-05 15:56:37","problem_types":["CWE-787","CWE-787 CWE-787 (Out-of-bounds Write)"],"metrics":[],"configurations":[]},"legacy_mitre":{"record":{"CveYear":"2026","CveId":"10879","Ordinal":"1","Title":"DBI versions before 1.648 for Perl have a heap overflow when pre","CVE":"CVE-2026-10879","Year":"2026"},"notes":[{"CveYear":"2026","CveId":"10879","Ordinal":"1","NoteData":"DBI versions before 1.648 for Perl have a heap overflow when preparsing SQL statements with more than 9 binders.\n\nThe preparse method expands SQL placeholder characters to numbered binders of the form :pN, but only allocates three characters per binder in the buffer.  Placeholders 10-99 require four characters, 100-999 require five characters, et cetera.","Type":"Description","Title":"DBI versions before 1.648 for Perl have a heap overflow when pre"}]}}}