← voltar
CVE-2023-34241

CUPS vulnerable to use-after-free in cupsdAcceptClient()

CVSS 5.3 MEDIUMEPSS 1.4%CWE-416
Em resumo

O CUPS (sistema de impressão) possui um erro onde tenta usar informações de uma conexão já fechada ao fazer registros de log. Isso pode fazer o serviço de impressão parar ou funcionar de forma instável.

Detalhe técnico

Vulnerabilidade de use-after-free na função cupsdAcceptClient() acionada quando httpClose() libera a memória da conexão antes de cupsdLogClient() tentar acessá-la via httpGetHostname(). Ocorre quando LogLevel está em warn ou superior com falha em buscas DNS reverso (HostNameLookups Double) ou rejeição de conexão por TCP wrappers. Afeta CUPS versões 2.0.0 até 2.4.5 e compromete a estabilidade do daemon cupsd.

Resumo gerado e traduzido por IA a partir da descrição oficial.
OpenPrinting CUPS is a standards-based, open source printing system for Linux and other Unix-like operating systems. Starting in version 2.0.0 and prior to version 2.4.6, CUPS logs data of free memory to the logging service AFTER the connection has been closed, when it should have logged the data right before. This is a use-after-free bug that impacts the entire cupsd process. The exact cause of this issue is the function `httpClose(con->http)` being called in `scheduler/client.c`. The problem is that httpClose always, provided its argument is not null, frees the pointer at the end of the call, only for cupsdLogClient to pass the pointer to httpGetHostname. This issue happens in function `cupsdAcceptClient` if LogLevel is warn or higher and in two scenarios: there is a double-lookup for the IP Address (HostNameLookups Double is set in `cupsd.conf`) which fails to resolve, or if CUPS is compiled with TCP wrappers and the connection is refused by rules from `/etc/hosts.allow` and `/etc/hosts.deny`. Version 2.4.6 has a patch for this issue.
CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:L
Produtos afetados
OpenPrinting · cups

Quer saber se a sua infraestrutura está exposta a isto?

Falar com a TrueHacking →