PT-2022-26047 · Go+3 · Go+3

Neil

·

Publicado

2022-12-07

·

Atualizado

2026-03-10

·

CVE-2022-41720

CVSS v3.1

7.5

Alta

VetorAV:N/AC:L/PR:N/UI:N/S:U/C:H/I:N/A:N
Nome do software vulnerável e versões afetadas
Versões do Go anteriores à versão corrigida
Descrição
A vulnerabilidade permite que arquivos restritos sejam acessados por meio de os.DirFS e http.Dir no Windows. Essas funções fornecem acesso a uma árvore de arquivos com raiz em um determinado diretório e permitem o acesso a arquivos de dispositivos do Windows sob essa raiz. Por exemplo, os.DirFS(“C:/tmp”).Open(“COM1”) abre o dispositivo COM1. Tanto os.DirFS quanto http.Dir fornecem apenas acesso somente leitura ao sistema de arquivos. Além disso, no Windows, um os.DirFS para o diretório (a raiz da unidade atual) pode permitir que um caminho criado de forma maliciosa escape da unidade e acesse qualquer caminho no sistema. O comportamento de os.DirFS(“”) mudou com a correção aplicada; anteriormente, tratava uma raiz vazia de forma equivalente a “/”, e agora retorna um erro.
Recomendações
Para versões do Go anteriores à versão corrigida, considere aplicar a correção para alterar o comportamento de os.DirFS(“”) de modo que retorne um erro em vez de tratá-lo de forma equivalente a “/”. Como solução alternativa temporária, restrinja o uso de os.DirFS e http.Dir para minimizar o risco de exploração. Evite usar os.DirFS com raízes vazias ou caminhos criados de forma maliciosa até que o problema seja resolvido.

Correção

Path traversal

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

Enumeração de Fraquezas

Identificadores relacionados

ALT-PU-2022-3297
ALT-PU-2022-3300
ALT-PU-2023-1205
ALT-PU-2023-1323
ALT-PU-2023-4785
AZL-79038
BIT-GOLANG-2022-41720
CVE-2022-41720
GO-2022-1143
OPENSUSE-SU-2022_4397-1
OPENSUSE-SU-2022_4398-1
OPENSUSE-SU-2024:12552-1
OPENSUSE-SU-2024:12553-1
SUSE-SU-2022:4397-1
SUSE-SU-2022:4398-1
SUSE-SU-2023:0871-1
SUSE-SU-2023:2312-1
SUSE-SU-2023_0871-1

Produtos afetados

Alt Linux
Debian
Go
Suse