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

exploitDog

github логотип

GHSA-526j-mv3p-f4vv

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

Описание

eKuiper API endpoints handling SQL queries with user-controlled table names.

Summary

A critical SQL Injection vulnerability exists in the getLast API functionality of the eKuiper project. This flaw allows unauthenticated remote attackers to execute arbitrary SQL statements on the underlying SQLite database by manipulating the table name input in an API request. Exploitation can lead to data theft, corruption, or deletion, and full database compromise.

Details

The root cause lies in the use of unsanitized user-controlled input when constructing SQL queries using fmt.Sprintf, without validating the table parameter. Specifically, in:

query := fmt.Sprintf("SELECT * FROM %s ORDER BY rowid DESC LIMIT 1", table)

Any value passed as the table parameter is directly interpolated into the SQL string, enabling injection attacks. This is reachable via API interfaces that expose time-series queries.

PoC

  1. Deploy eKuiper instance (default config is sufficient).
  2. Send a crafted request to the SQL query endpoint:
curl -X POST http://localhost:9081/sql-query \ -H "Content-Type: application/json" \ -d '{ "table": "sensors; DROP TABLE users; --", "operation": "getLast" }'
  1. Effect: Executes two SQL queries — the first selects data, the second drops the users table.
  2. Verify Result:
sqlite3 etc/kuiper/data/kuiper.db ".tables"

Impact

CWE-89: Improper Neutralization of Special Elements used in an SQL Command ('SQL Injection')

Refferences

Пакеты

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

github.com/lf-edge/ekuiper/v2

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

< 2.2.1

2.2.1

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

github.com/lf-edge/ekuiper

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

<= 1.14.7

Отсутствует

EPSS

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

8.9 High

CVSS4

Дефекты

CWE-89

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

CVSS3: 9.8
nvd
7 месяцев назад

LF Edge eKuiper is a lightweight IoT data analytics and stream processing engine running on resource-constraint edge devices. In versions before 2.2.1, there is a critical SQL Injection vulnerability in the getLast API functionality of the eKuiper project. This flaw allows unauthenticated remote attackers to execute arbitrary SQL statements on the underlying SQLite database by manipulating the table name input in an API request. Exploitation can lead to data theft, corruption, or deletion, and full database compromise. This is fixed in version 2.2.1.

EPSS

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

8.9 High

CVSS4

Дефекты

CWE-89