PT-2025-29948 · Openzeppelin · Openzeppelin Contracts

Amxx

·

Publicado

2025-07-17

·

Atualizado

2025-07-17

·

CVE-2025-54070

CVSS v4.0

6.9

Média

VetorAV:N/AC:L/AT:N/PR:N/UI:N/VC:N/VI:L/VA:L/SC:N/SI:N/SA:N/E:X/CR:X/IR:X/AR:X/MAV:X/MAC:X/MAT:X/MPR:X/MUI:X/MVC:X/MVI:X/MVA:X/MSC:X/MSI:X/MSA:X/S:X/AU:X/R:X/V:X/RE:X/U:X
Nome do Software Vulnerável e Versões Afetadas OpenZeppelin Contracts versões 5.2.0 a 5.3.9
Descrição A função lastIndexOf(bytes,byte,uint256) na biblioteca Bytes.sol pode acessar memória não inicializada sob condições específicas. Isso ocorre quando o comprimento do buffer fornecido é zero (buffer.length == 0) e a posição (pos) não é igual ao valor máximo para um inteiro sem sinal de 256 bits (type(uint256).max). O argumento pos pode ser usado para acessar dados fora dos limites pretendidos do buffer, potencialmente levando a erros de out-of-gas ou ao retorno de um índice inválido. A função lê a memória no offset buffer + 0x20 + pos. Se a memória nesse local corresponder ao padrão de busca, a função retorna um índice fora dos limites em vez do valor máximo esperado. Código que depende do retorno de type(uint256).max pela função para buffers vazios ou que utiliza o índice retornado sem verificação de limites pode apresentar comportamento indefinido.
Recomendações OpenZeppelin Contracts versões 5.2.0 a 5.3.9: Atualize para a versão 5.4.0.

Exploit

Correção

Out of bounds Read

Encontrou algum problema na descrição? Tem algo a acrescentar? Fique à vontade para nos escrever 👾

Enumeração de Fraquezas

Identificadores relacionados

CVE-2025-54070
GHSA-9RCW-C2F9-2J55

Produtos afetados

Openzeppelin Contracts