Home

Description

tiny-secp256k1 is a tiny secp256k1 native/JS wrapper. Prior to version 1.1.7, a private key can be extracted on signing a malicious JSON-stringifiable object, when global Buffer is the buffer package. This affects only environments where require('buffer') is the NPM buffer package. The Buffer.isBuffer check can be bypassed, resulting in k reuse for different messages, leading to private key extraction over a single invalid message (and a second one for which any message/signature could be taken, e.g. previously known valid one). This issue has been patched in version 1.1.7.

PUBLISHED Reserved 2024-10-14 | Published 2025-07-01 | Updated 2025-07-01 | Assigner GitHub_M




HIGH: 8.1CVSS:4.0/AV:N/AC:L/AT:P/PR:N/UI:N/VC:H/VI:H/VA:N/SC:N/SI:N/SA:N/E:P

Problem types

CWE-522: Insufficiently Protected Credentials

Product status

< 1.1.7
affected

References

github.com/...p256k1/security/advisories/GHSA-7mc2-6phr-23xc exploit

github.com/...p256k1/security/advisories/GHSA-7mc2-6phr-23xc

github.com/bitcoinjs/tiny-secp256k1/pull/140

cve.org (CVE-2024-49364)

nvd.nist.gov (CVE-2024-49364)

Download JSON