Double Public Key Signing Function Oracle Attack on Ed25519
The standard specification of Ed25519 message signing involves providing the algorithm with a message and private key.
The function will use the private key to compute the public key and sign the message. Some libraries provide a variant of the message signing function that also takes the pre-computed public key as an input parameter.
Libraries that allow arbitrary public keys as inputs without checking if the input public key corresponds to the input private key are vulnerable to the following attack.
By using several public keys and messages, a malicious user with access to the signing mechanism may build up insights into the private key parameters resulting in access to the private key.
This shortcoming means that an attacker could use the signing function as an Oracle, perform crypto-analysis and ultimately get at secrets. For example, an attacker who can’t access the private key but can access the signing mechanism through an API call could use several public keys and messages to gradually build up insights into private key parameters.
Info
- Published
- April 03, 2025
- Modified
- April 03, 2025
- CAPECs
- < none >
- CWEs
- < none >
- Keywords
- crypto
- Aliases
- < none >
- Related
- GHSA-w5vr-6qhr-36cc
- References
- [ARTICLE] https://portswigger.net/daily-swig/dozens-of-cryptography-libraries-vulnerable-to-private-key-theft
- [ARTICLE] https://github.com/MystenLabs/ed25519-unsafe-libs
- [ADVISORY] https://github.com/advisories/GHSA-w5vr-6qhr-36cc
- [EVIDENCE] https://hackage.haskell.org/package/cryptonite-0.30/docs/src/Crypto.PubKey.Ed25519.html#sign
- [EVIDENCE] https://github.com/haskell-crypto/cryptonite/blob/cryptonite-v0.30/cbits/ed25519/ed25519.c#53
- [EVIDENCE] https://github.com/kazu-yamamoto/crypton/blob/48fb9df2de5ee752196724b081f4d3cdb57576ed/cbits/ed25519/ed25519.c#L53
- [FIX] https://github.com/kazu-yamamoto/crypton/pull/47
Affected
cryptonite
- CVSS
- CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:C/C:N/I:H/A:N
- Versions
>=0.1
- Declarations
- < none >
crypton
- CVSS
- CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:C/C:N/I:H/A:N
- Versions
>=0.31 && <1.0.3
- Declarations
- < none >