DataEase — это платформа визуализации и анализа данных с открытым исходным кодом. Версии 2.10.20 и ниже содержат уязвимость внедрения SQL в конечной точке /datasource/getTableField. Метод getTableFiledSql в CalciteProvider.java включает параметр tableName непосредственно в строки запроса SQL с использованием String.format без параметризации или очистки.
Хотя DatasourceServer.java проверяет наличие имени таблицы в источнике данных, злоумышленник может обойти это, сначала зарегистрировав источник данных API с вредоносным именем deTableName, которое затем возвращается методом getTables и проходит проверку проверки. Аутентифицированный злоумышленник может выполнять произвольные команды SQL, что позволяет извлекать конфиденциальную информацию базы данных на основе ошибок. Эта проблема исправлена в версии 2.10.21.
Показать оригинальное описание (EN)
DataEase is an open-source data visualization and analytics platform. Versions 2.10.20 and below contain a SQL injection vulnerability in the /datasource/getTableField endpoint. The getTableFiledSql method in CalciteProvider.java incorporates the tableName parameter directly into SQL query strings using String.format without parameterization or sanitization. Although DatasourceServer.java validates that the table name exists in the datasource, an attacker can bypass this by first registering an API datasource with a malicious deTableName, which is then returned by getTables and passes the validation check. An authenticated attacker can execute arbitrary SQL commands, enabling error-based extraction of sensitive database information. This issue has been fixed in version 2.10.21.
Характеристики атаки
Последствия
Строка CVSS v4.0