Логотип exploitDog
Консоль
Логотип exploitDog

exploitDog

github логотип

GHSA-j8hp-f2mj-586g

Опубликовано: 24 окт. 2024
Источник: github
Github: Прошло ревью
CVSS3: 5.9

Описание

OpenRefine's error page lacks escaping, leading to potential Cross-site Scripting on import of malicious project

Summary

The built-in "Something went wrong!" error page includes the exception message and exception traceback without escaping HTML tags, enabling injection into the page if an attacker can reliably produce an error with an attacker-influenced message.

It appears that the only way to reach this code in OpenRefine itself is for an attacker to somehow convince a victim to import a malicious file, as in GHSA-m88m-crr9-jvqq, which may be difficult. However, out-of-tree extensions may add their own calls to respondWithErrorPage.

Details

The Command.respondWithErrorPage (through HttpUtilities.respondWithErrorPage) function renders the Velocity template error.vt, which contains the $message and $stack variables, which are included in the response as-is:

https://github.com/OpenRefine/OpenRefine/blob/master/main/webapp/modules/core/error.vt#L52-L53

However, the message can contain HTML tags, which would then be interpreted by the browser. A mitigation would be to escape both the message and stack trace, perhaps using Guava's HTML escaper.

Flows that report errors as application/json responses are not interpreted by the browser and so not affected by this issue.

PoC

In OpenRefine, use the "Import project" feature to import the following URL (or upload it as a file): https://wandernauta.nl/oa/example.tar.gz

A JavaScript alert appears.

Impact

Execution of arbitrary JavaScript in the victim's browser, provided the victim can be convinced to import a malicious project. The script can do anything the user can do.

Пакеты

Наименование

org.openrefine:openrefine

maven
Затронутые версииВерсия исправления

< 3.8.3

3.8.3

EPSS

Процентиль: 35%
0.00147
Низкий

5.9 Medium

CVSS3

Дефекты

CWE-79
CWE-81

Связанные уязвимости

CVSS3: 5.9
ubuntu
больше 1 года назад

OpenRefine is a free, open source tool for working with messy data. Prior to version 3.8.3, the built-in "Something went wrong!" error page includes the exception message and exception traceback without escaping HTML tags, enabling injection into the page if an attacker can reliably produce an error with an attacker-influenced message. It appears that the only way to reach this code in OpenRefine itself is for an attacker to somehow convince a victim to import a malicious file, which may be difficult. However, out-of-tree extensions may add their own calls to `respondWithErrorPage`. Version 3.8.3 has a fix for this issue.

CVSS3: 5.9
nvd
больше 1 года назад

OpenRefine is a free, open source tool for working with messy data. Prior to version 3.8.3, the built-in "Something went wrong!" error page includes the exception message and exception traceback without escaping HTML tags, enabling injection into the page if an attacker can reliably produce an error with an attacker-influenced message. It appears that the only way to reach this code in OpenRefine itself is for an attacker to somehow convince a victim to import a malicious file, which may be difficult. However, out-of-tree extensions may add their own calls to `respondWithErrorPage`. Version 3.8.3 has a fix for this issue.

CVSS3: 5.9
debian
больше 1 года назад

OpenRefine is a free, open source tool for working with messy data. Pr ...

EPSS

Процентиль: 35%
0.00147
Низкий

5.9 Medium

CVSS3

Дефекты

CWE-79
CWE-81