Advisory Database
  • Advisories
  • Dependency Scanning
  1. npm
  2. ›
  3. @ensdomains/ens-contracts
  4. ›
  5. CVE-2023-38698

CVE-2023-38698: Integer Overflow or Wraparound

August 1, 2023 (updated August 10, 2023)

Ethereum Name Service (ENS) is a distributed, open, and extensible naming system based on the Ethereum blockchain. According to the documentation, controllers are allowed to register new domains and extend the expiry of existing domains, but they cannot change the ownership or reduce the expiration time of existing domains. However, a preliminary analysis suggests that an attacker-controlled controller may be able to reduce the expiration time of existing domains due to an integer overflow in the renew function. The vulnerability resides @ensdomains/ens-contracts prior to version 0.0.22.

If successfully exploited, this vulnerability would enable attackers to force the expiration of any ENS record, ultimately allowing them to claim the affected domains for themselves. Currently, it would require a malicious DAO to exploit it. Nevertheless, any vulnerability present in the controllers could potentially render this issue exploitable in the future. An additional concern is the possibility of renewal discounts. Should ENS decide to implement a system that offers unlimited .eth domains for a fixed fee in the future, the vulnerability could become exploitable by any user due to the reduced attack cost.

Version 0.0.22 contains a patch for this issue. As long as registration cost remains linear or superlinear based on registration duration, or limited to a reasonable maximum (eg, 1 million years), this vulnerability could only be exploited by a malicious DAO. The interim workaround is thus to take no action.

References

  • github.com/advisories/GHSA-rrxv-q8m4-wch3
  • github.com/ensdomains/ens-contracts/blob/master/contracts/ethregistrar/BaseRegistrarImplementation.sol
  • github.com/ensdomains/ens-contracts/commit/e6b136e979084de3761c125142620304173990ca
  • github.com/ensdomains/ens-contracts/security/advisories/GHSA-rrxv-q8m4-wch3
  • nvd.nist.gov/vuln/detail/CVE-2023-38698

Code Behaviors & Features

Detect and mitigate CVE-2023-38698 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 0.0.21

Fixed versions

  • 0.0.22

Solution

Upgrade to version 0.0.22 or above.

Impact 6.5 MEDIUM

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

Learn more about CVSS

Weakness

  • CWE-190: Integer Overflow or Wraparound
  • CWE-78: Improper Neutralization of Special Elements used in an OS Command ('OS Command Injection')

Source file

npm/@ensdomains/ens-contracts/CVE-2023-38698.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:08 +0000.