CVE-2023-38698

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.
Configurations

Configuration 1 (hide)

cpe:2.3:a:ens.domains:ethereum_name_service:*:*:*:*:*:*:*:*

History

21 Nov 2024, 08:14

Type Values Removed Values Added
Summary
  • (es) Ethereum Name Service (ENS) es un sistema de nombres distribuido, abierto y extensible basado en la blockchain de Ethereum. Según la documentación, los controladores pueden registrar nuevos dominios y ampliar la caducidad de los existentes, pero no pueden cambiar la titularidad ni reducir el tiempo de caducidad de los dominios existentes. Sin embargo, un análisis preliminar sugiere que un controlador controlado por un atacante puede ser capaz de reducir el tiempo de expiración de los dominios existentes debido a un desbordamiento de enteros en la función renew. La vulnerabilidad reside en `@ensdomains/ens-contracts` anterior a la versión 0.0.22. Si se explota con éxito, esta vulnerabilidad permitiría a los atacantes forzar la expiración de cualquier registro ENS, permitiéndoles en última instancia reclamar para sí los dominios afectados. Actualmente, se requeriría un DAO malicioso para explotarla. No obstante, cualquier vulnerabilidad presente en los controladores podría hacer que este problema pudiera explotarse en el futuro. Una preocupación adicional es la posibilidad de descuentos en la renovación. Si ENS decide implementar un sistema que ofrezca dominios .eth ilimitados por una tarifa fija en el futuro, la vulnerabilidad podría ser explotable por cualquier usuario debido al reducido coste de ataque. La versión 0.0.22 contiene un parche para este problema. Mientras el coste de registro siga siendo lineal o superlineal en función de la duración del registro, o limitado a un máximo razonable (por ejemplo, 1 millón de años), esta vulnerabilidad sólo podría ser explotada por una DAO maliciosa. Por lo tanto, la solución provisional es no tomar ninguna medida.
References () https://github.com/ensdomains/ens-contracts/blob/master/contracts/ethregistrar/BaseRegistrarImplementation.sol#L171 - Product () https://github.com/ensdomains/ens-contracts/blob/master/contracts/ethregistrar/BaseRegistrarImplementation.sol#L171 - Product
References () https://github.com/ensdomains/ens-contracts/commit/e6b136e979084de3761c125142620304173990ca - Patch () https://github.com/ensdomains/ens-contracts/commit/e6b136e979084de3761c125142620304173990ca - Patch
References () https://github.com/ensdomains/ens-contracts/security/advisories/GHSA-rrxv-q8m4-wch3 - Exploit, Vendor Advisory () https://github.com/ensdomains/ens-contracts/security/advisories/GHSA-rrxv-q8m4-wch3 - Exploit, Vendor Advisory
CVSS v2 : unknown
v3 : 6.5
v2 : unknown
v3 : 4.9

10 Aug 2023, 15:33

Type Values Removed Values Added
CPE cpe:2.3:a:ens.domains:ethereum_name_service:*:*:*:*:*:*:*:*
CVSS v2 : unknown
v3 : unknown
v2 : unknown
v3 : 6.5
References (MISC) https://github.com/ensdomains/ens-contracts/commit/e6b136e979084de3761c125142620304173990ca - (MISC) https://github.com/ensdomains/ens-contracts/commit/e6b136e979084de3761c125142620304173990ca - Patch
References (MISC) https://github.com/ensdomains/ens-contracts/blob/master/contracts/ethregistrar/BaseRegistrarImplementation.sol#L171 - (MISC) https://github.com/ensdomains/ens-contracts/blob/master/contracts/ethregistrar/BaseRegistrarImplementation.sol#L171 - Product
References (MISC) https://github.com/ensdomains/ens-contracts/security/advisories/GHSA-rrxv-q8m4-wch3 - (MISC) https://github.com/ensdomains/ens-contracts/security/advisories/GHSA-rrxv-q8m4-wch3 - Exploit, Vendor Advisory

04 Aug 2023, 18:53

Type Values Removed Values Added
New CVE

Information

Published : 2023-08-04 18:15

Updated : 2024-11-21 08:14


NVD link : CVE-2023-38698

Mitre link : CVE-2023-38698

CVE.ORG link : CVE-2023-38698


JSON object : View

Products Affected

ens.domains

  • ethereum_name_service
CWE
CWE-190

Integer Overflow or Wraparound