Lucene search

K
friendsofphpOpenJS FoundationFRIENDSOFPHP:DANTER:ECC:2024-04-24
HistoryApr 24, 2024 - 12:00 a.m.

Cryptographic side-channels in PHPECC

2024-04-2400:00:00
OpenJS Foundation
github.com
2
php
ecdsa
security fixes
cryptography
migration guide
composer
constanttimemath

6.5 Medium

AI Score

Confidence

Low

Description ECDSA Canonicalization PHPECC is vulnerable to malleable ECDSA signature attacks. Constant-Time Signer When generating a new ECDSA signature, the GMPMath adapter was used. This class wraps the GNU Multiple Precision arithmetic library (GMP), which does not aim to provide constant-time implementations of algorithms. An attacker capable of triggering many signatures and studying the time it takes to perform each operation would be able to leak the secret number, k, and thereby learn the private key. EcDH Timing Leaks When calculating a shared secret using the EcDH class, the scalar-point multiplication is based on the arithmetic defined by the Point class. Even though the library implements a Montgomery ladder, the add(), mul(), and getDouble() methods on the Point class are not constant-time. This means that your ECDH private keys are leaking information about each bit of your private key through a timing side-channel. References https://github.com/FriendsOfPHP/security-advisories/blob/master/mdanter/ecc/2024-04-24.yaml https://github.com/paragonie/phpecc/releases/tag/v2.0.0

Affected configurations

Vulners
Node
mdantereccRange<2.0.0
CPENameOperatorVersion
mdanter/ecclt2.0.0

6.5 Medium

AI Score

Confidence

Low