Advisory Database
  • Advisories
  • Dependency Scanning
  1. composer
  2. ›
  3. mdanter/ecc
  4. ›
  5. GHSA-346h-749j-r28w

GHSA-346h-749j-r28w: PHPECC vulnerable to multiple cryptographic side-channel attacks

April 25, 2024

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

  • github.com/FriendsOfPHP/security-advisories/blob/master/mdanter/ecc/2024-04-24.yaml
  • github.com/advisories/GHSA-346h-749j-r28w
  • github.com/paragonie/phpecc/releases/tag/v2.0.0
  • github.com/phpecc/phpecc

Code Behaviors & Features

Detect and mitigate GHSA-346h-749j-r28w with GitLab Dependency Scanning

Secure your software supply chain by verifying that all open source dependencies used in your projects contain no disclosed vulnerabilities. Learn more about Dependency Scanning →

Affected versions

All versions up to 1.0.0

Solution

Unfortunately, there is no solution available yet.

Impact 9.1 CRITICAL

CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:N

Learn more about CVSS

Weakness

  • CWE-203: Observable Discrepancy
  • CWE-354: Improper Validation of Integrity Check Value

Source file

packagist/mdanter/ecc/GHSA-346h-749j-r28w.yml

Spotted a mistake? Edit the file on GitLab.

  • Site Repo
  • About GitLab
  • Terms
  • Privacy Statement
  • Contact

Page generated Wed, 14 May 2025 12:16:16 +0000.