Описание
cggmp24 and cggmp21 are vulnerable to signature forgery through altered presignatures
Impact
This attack is against presignatures used in very specific context:
- Presignatures + HD wallets derivation: security level reduces to 85 bits
Previously users could generate a presignature, and then choose a HD derivation path while issuing a partial signature viaPresignature::set_derivation_path, which is malleable to attack that reduces target security level. To mitigate, this method has been removed from API. - Presignatures + "raw signing" (when signer signs a hash without knowing an original message): results into signature forgery attack
Previously, users were able to configurePresignature::issue_partial_signaturewith hashed message without ever providing original mesage. In new API, this method only accepts digests for which original message has been observed.
Patches
cggmp24 v0.7.0-alpha.2 release contains API changes that make it impossible to use presignatures in contexts in which it reduces security. Follow migration guidelines to upgrade.
Workarounds
Users can continue using un-patched versions of library as long as they don't use presignatures in said scenarios where it weakens system security. To be sure, migrate to patched version that excludes presignatures from being used in such scenarios.
References
Read this blog post to learn more.
Ссылки
- https://github.com/LFDT-Lockness/cggmp21/security/advisories/GHSA-8frv-q972-9rq5
- https://nvd.nist.gov/vuln/detail/CVE-2025-66017
- https://github.com/LFDT-Lockness/cggmp21/commit/9d98157e151596573cb071da59d27a4e0ac9b8dc
- https://rustsec.org/advisories/RUSTSEC-2025-0127.html
- https://rustsec.org/advisories/RUSTSEC-2025-0128.html
- https://www.dfns.co/article/cggmp21-vulnerabilities-patched-and-explained
Пакеты
cggmp21
<= 0.6.3
Отсутствует
cggmp24
< 0.7.0-alpha.2
0.7.0-alpha.2
Связанные уязвимости
CGGMP24 is a state-of-art ECDSA TSS protocol that supports 1-round signing (requires 3 preprocessing rounds), identifiable abort, and a key refresh protocol. In versions 0.6.3 and prior of cggmp21 and version 0.7.0-alpha.1 of cggmp24, presignatures can be used in the way that significantly reduces security. cggmp24 version 0.7.0-alpha.2 release contains API changes that make it impossible to use presignatures in contexts in which it reduces security.